Pythonのお勉強 Part69

■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん (ワッチョイ c733-stRS)
垢版 |
2022/11/24(木) 21:39:44.67ID:A6xfpKBe0
!extend:default:vvvvv:1000:1024
↑スレ立てる毎に減るので、減ってたら3つに補充すること。

・当スレにRubyのソースコード類を書くことを禁ず
・Ruby等、Pythonではないプログラミング言語での回答類・質問を書くのも禁止
・「Ruby では」「Rubyでは」「Rails」正規表現→「^クソチョンw$」をNGワード登録推奨
・エラーを解決したいときは、かならず
 エラー文(勝手に省略orスクショうp等の横着禁止)と
 おま環(Pythonのバージョン番号+OS名とバージョン+IDE名)を書け。

★Pythonのソースコードを5ちゃんに直貼はインデントが崩壊するので、
  ↓等のコードうp用サイトに貼ってきてくだしあ。(スクリーンショットをうpる「横着」禁止)
ttps://techiedelight.com/compiler/  Run Code機能あり。
ttp://ideone.com/      デフォ設定がCなので、Pythonするには言語種選択ボタン押下がピコ手間かも。
ttp://pastebin.com/     まずまずシンプル。
ttp://dpaste.com/      とてもシンプル。消えるまでの日数は十分長ーく指定のこと。

◇Pythonオフィシャルサイト http://www.python.org/
◇Pythonドキュメント https://docs.python.org/ja/3/
◇まとめwiki ttp://python.rdy.jp/

●関連スレ● 自称初心者は↓へ
【まず1嫁】くだすれPython(超初心者用) その58
https://mevius.5ch.net/test/read.cgi/tech/1662514433/

〇前スレ〇
Pythonのお勉強 Part68
https://mevius.5ch.net/test/read.cgi/tech/1663235546/

次スレの建立は>>985が挑戦する。(980通過して24h後も落ちなくなった)
### END of TEMPLATE ### ?
VIPQ2_EXTDAT: default:vvvvv:1000:512:: EXT was configured
2023/01/21(土) 02:08:14.13ID:8Gumyjw80
ChatGPTがいいよ
730デフォルトの名無しさん (ワッチョイ cf46-l+ta)
垢版 |
2023/01/21(土) 02:58:00.85ID:Bxvmrygr0
>>723
その ideone.com/S6X4NB の実行結果は match line: 4 になっている。
4行目しか、/りんご.*れた/ にマッチしてないのでは。

「複数行にまたがる正規表現」ということなら、2~5行目にかけた
"りんごが1個3 りんご4 りんごが2個うれた5 売れた"
にマッチし、match line: 2 が返りそうな気がする。
2023/01/21(土) 04:51:17.18ID:+3UW7oH80
ほんとだ
re.MULTILINEじゃなくてre.DOTALLが正解でしたね
2023/01/21(土) 13:38:37.90ID:5rRYrQvt0
みんな引数書くとき型ヒントつけてる?
Intelicenseのためになるべくつけるようにしたいんだけど
あえてつけない方がいいって意見あったりする?
2023/01/21(土) 14:01:26.32ID:fUOngKcuM
>>732
使ってないなあ
使わなくても動くものは使わなくていい
シンプルイズベスト
2023/01/21(土) 14:32:39.33ID:A7VrgYN70
俺は書く。
引数の型なんて昔からコメントに書いてたしなぁ。
2023/01/21(土) 16:32:06.79
AIで勝手につけてもらったほうが楽だったりして
https://i.imgur.com/EyAlxnO.jpg
2023/01/21(土) 17:06:12.97ID:EhE1HfEs0
>>732
書ける型は必ず書くかな
なくても理解できるなんてまやかしだからね
一人で数百行のスクリプト書くだけなら好きにすればいいけど
2023/01/21(土) 17:54:45.51ID:N4/N+WFUd
俺も書く
明日の自分は別人だとおもってるから
2023/01/21(土) 18:03:08.29ID:6NqTTwhj0
必要そうだと思えば書く
一律には決めない
739デフォルトの名無しさん (ワッチョイ a397-xFde)
垢版 |
2023/01/21(土) 18:29:49.08ID:vxlp1VLj0
分析用のコードとか簡単なアルゴリズム検証用のプロトでは書かないけど、
それなりに運用される前提のコードなら書くかなあ。
2023/01/21(土) 21:58:12.42ID:CGLAOxtya
コメントもアノテーションも書いたら負け
書かなくとも直感的に頭の中に入ってくるコードを書くのは必然
2023/01/21(土) 22:05:29.47ID:qRfy1PGha
変数名は6文字以下
2023/01/21(土) 22:32:25.46ID:8msiXC4t0
コメントはわかるが型書くのはバグ、デグレ回避だからな
2023/01/22(日) 00:43:00.91ID:alhRdr+00
皆さんありがとうごおざいます。
強く忌避される理由もなさそうなので遠慮なく使っていこうかと思います。
2023/01/22(日) 09:46:38.39ID:mu8Nl5mu0
昔はコメントは1行ごとに書けと言われていたがな。
コメントのみ抽出してテスト項目書にするから。
2023/01/22(日) 10:25:05.16ID:sXfLTPHJ0
昔の人ってバカだったんですね
2023/01/22(日) 10:36:24.49ID:mu8Nl5mu0
テスト担当は本来自分じゃないんだぞ。
2023/01/22(日) 10:56:53.83ID:Z9h86Jnh0
本文のコメントをテスト項目書に書くってどいうことだろ
2023/01/22(日) 11:07:16.38ID:Dp7umTA90
まだ網羅とかの概念が無かった頃かな
2023/01/22(日) 11:20:11.52ID:mu8Nl5mu0
そうだね。ちょうどカバレッジ(率)という用語が出てきてプログラム化されてきたかなという頃だな。
2023/01/22(日) 11:26:46.20ID:dLuJ8Aewd
>>744
言われてないぞ
2023/01/22(日) 11:39:32.26ID:vp80yT++0
>>744
コードの行数とコメントの行数が同じになるの?
2023/01/22(日) 13:19:21.37ID:Z9h86Jnh0
逆になんでコメントなんだろうと思った。
コードそのまま写した方が手間も間違いも無くてよさそうに思うが。
2023/01/22(日) 14:08:53.41ID:mu8Nl5mu0
言われていないなら言われていないでいいよ。
別に書かなくても誰も困ってないんだろ。

コードで行っている処理を日本語などの言語で表現できないような状態はバグの温床だな。
2023/01/22(日) 14:36:52.28ID:CeTBqGTsd
>>753
生産性の悪い、規約でがんじがらめの現場しか経験してないのかな
コメントは処理の内容じゃなく、なぜその処理かを記述するんだよ
何やってるかなんてコード読めば済むだろ
2023/01/22(日) 14:46:00.56ID:lD3V8UVm
こういうことをしたいんだがもっと上手く書けないもんかな・・
https://ideone.com/QYEWI4
等分割ではなくて等比的に分割していく、みたいな

微妙にsum結果が合ってないのも気になる
2023/01/22(日) 15:08:55.72ID:mu8Nl5mu0
floatだからじゃないの?decimal使ったら?
757デフォルトの名無しさん (ブーイモ MM1f-/qsW)
垢版 |
2023/01/22(日) 15:36:21.63ID:++gHrjAvM
おあつらえ向きに何がやりたいかわからんコメントが必要なコードが出てきたぞ
2023/01/22(日) 15:57:16.18ID:Z9h86Jnh0
ふつうはその関数の仕様や期待動作をコメントに書くんだよ
759デフォルトの名無しさん (ワッチョイ 4376-gzmJ)
垢版 |
2023/01/22(日) 16:15:50.88ID:6lZDc9UV0
sideとexの意図がわからんから無視したが、
だいたいこんな感じになれば満足か?

def divisionor(source, ratio, maxcount):
for _ in range(maxcount):
yield source
source*=ratio

def step_values(sumvalue, ratio, step):
firstvalue = sumvalue * (1-ratio) / (1-ratio**step)
return list(divisionor(firstvalue, ratio, step))

print(step_values(11111, 0.1, 5))
2023/01/22(日) 17:26:38.16ID:KzI8pxO80
この行は何をしたいのか
なぜこの選択肢を取ったのか
この選択肢を試してみたがこういう方法でうまくいかない

とかをコメントで残しておいてくれると
後々助かる
2023/01/22(日) 17:57:02.93ID:tbxzfOk70
そもそもそういうコメントが不要なコードのがよくない?
ちゃんとレビューしよう
2023/01/22(日) 19:17:12.88ID:Dp7umTA90
関数名や変数名から想像した通りに動作をするならコメントは要らない
予想を裏切る行動をする箇所だけコメントが必要

そんな書き方するなという話だけど、そうしないといけない時もある
外部のバグに合わせて仕方なく変なことするとか
再帰呼び出しもコメントが無いとパッと見て判らない
763デフォルトの名無しさん (ワッチョイ cf46-l+ta)
垢版 |
2023/01/22(日) 21:39:41.12ID:rHuBFYoH0
>>761
> そもそもそういうコメントが不要なコードのがよくない?

それ、ドキュメント書きを怠けたい人の方便だからね。
誰に聞いたか知らないが、真に受けるのはやめよう。
そもそも、そうのたまう人が説明不要なコードを書いた試し無いでしょ。
2023/01/22(日) 21:50:50.32ID:HMT2GUgc0
コメントは悪、という思想は悪
その正体は怠慢と傲慢
2023/01/22(日) 21:56:14.88ID:nZDUyUTud
>>760の言ってる内容はコードとして残せないから残す意味がある
処理の内容を書く奴は処理とコメントに矛盾が生じたときに困るし、
コードとコメントの双方を直すことになる奴だから残すべきじゃない
2023/01/22(日) 21:58:28.48ID:mu8Nl5mu0
>>765
同じことをいうヤツが何人もいるが、それは仕様自体を正しく把握してない状態では?
2023/01/22(日) 21:59:29.89ID:CYRi3QMt0
コメント欄は上司の悪口を書いておく場所です
2023/01/22(日) 22:00:55.76ID:tbxzfOk70
>>763
自分のコードでもレビューでもそう意識して実践してるけどダメ?
>>762のようなケースもあるからこそ
ノイズになるしょうもないコメントは書きたくないから
なるべくコードだけで分かるように心がけてる
2023/01/22(日) 22:04:13.87ID:vp80yT++0
# 何故動いているのか分からない

# 触るな!キケン!
2023/01/22(日) 22:10:16.22ID:9Ojcnz4Cd
>>766
仕様を把握してたらなおさらコードの内容をコメントとして書く理由がない
ある程度の規模のOSSのソース見てごらん
ちゃんと意味のあるコメントが書かれてる
2023/01/22(日) 22:23:35.47ID:o/PhajQ/0
>>765
コードコメントをAPIドキュメントとして使うよう場合は
仕様としての処理の内容をコメントに書く

それに「この行は何をしたいのか」は基本的にコードに書くべきこと
特にPythonのように高レベル言語では意図が伝わるコードを書くべき
2023/01/22(日) 22:28:26.52ID:CYRi3QMt0
# この先地雷原有り
2023/01/22(日) 22:29:55.26ID:/fZ7r7w/d
>>771
何をしたいのかと何をやってるのかは違うからね
コードから読み取れるのは何をやってるのか(how)だけであり、
なぜ(why)ややりたいこと(want to)は読み取れない
だからこそコードに残せない情報はコメントで残す意味がある
774デフォルトの名無しさん (JP 0H9f-xoCn)
垢版 |
2023/01/22(日) 22:54:57.29ID:R9Yr7t5mH
まともなコードを読めば
ドキュメントとコメントと適切な命名、型ヒントの重要性について学べるだろう

個人用の短い書き捨てのコードしか書かないんだったら好きにすりゃいい
2023/01/22(日) 23:02:22.21ID:bkKT3NQT0
コメントは分かりやすくするためだから長文でダラダラ説明じゃなく要点を端的に示せばいいよね
>>773のとおりどうやってやっているかはコード見ればいいから不要だけど何のための処理かとか入出力変数の内容はメモ欲しいかな
2023/01/22(日) 23:25:39.03ID:o/PhajQ/0
>>773
>何をしたいのかと何をやってるのかは違うからね
それ違ったらバグだよ
Whyは一般的にはコードに書けない
HowだけでなくWhatをコードに書く
それが意図を伝えるコード
2023/01/23(月) 02:03:11.45ID:iK9HS79n0
コメント書いてわかりやすくするなら
はじめからわかりやすいコードを書くことを心がけて行きたい
コメントやドキュメントに頼らずに直感的に頭の中にすっと入ってくるコードを目指すべき
778デフォルトの名無しさん (ワッチョイ a397-xFde)
垢版 |
2023/01/23(月) 08:55:05.46ID:e6QcTLyI0
ユークリッドの互助法みたいなのは、ユークリッドの互助法を行う、でいいと思うけど、
数式をプログラムにする際にやたらに複雑になってしまったような場合は概要だけでなく解説を入れるかな。
glibcのmath.cのcosとかいい例って感じするけど。
2023/01/23(月) 09:04:24.24ID:ZLTOxX5K0
いわゆる「下回り」は高速性も求められるので、難解になりがちだな
何ならアセンブラで書いてある

そういうダーティな部分は最下層に追いやって、上の方はクリーンに書くので、
そんな難解なものを書けるチャンスはまずやって来ない
780デフォルトの名無しさん (ブーイモ MMa7-xFde)
垢版 |
2023/01/23(月) 09:13:35.90ID:JALIr7W8M
>>779
numpyとかダーティになりがちだし、自分はnumpyのコードも書くからなあ。そう言うコメントを書く機会ある。
2023/01/23(月) 09:15:42.81ID:qV3QzySmp
あれは実際どの型で動いてるのか不安になる時あるわ
ちょっとコード変えたらエラー出まくりとか嫌になる
782デフォルトの名無しさん (アウアウウー Saa7-KLwc)
垢版 |
2023/01/23(月) 15:20:45.47ID:wy0Tx5tFa
普段からコメント書いたり読んだりしてないといきなりは難しい
2023/01/23(月) 15:25:29.48ID:ZLTOxX5K0
コメントとは違うけど、docopt ってよく出来てる
ドキュメントを書くとその通りに動く
あの無敵な感じを関数単位でやれるといい
2023/01/23(月) 19:31:40.09ID:Hk4+8ffPM
>>732
付けてるけど
Noneチェックしないとエラーになってうざいときある
785デフォルトの名無しさん (ブーイモ MMff-3swV)
垢版 |
2023/01/24(火) 01:38:47.57ID:k7nS/dQwM
30代Pythonクソチョン男は強姦魔の犯罪者!
あなたの近くにいます!
父母と祖父母の戸籍謄本を提出させましょう!
786デフォルトの名無しさん (ワッチョイ 6f7a-um8e)
垢版 |
2023/01/24(火) 23:55:50.38ID:NOigsG6z0
ウェブサイトのデータ抽出してからエクセルにデータ貼り付けて、
そこからさらに重複していないデータ(データ一覧に一つしか存在しないという意味、リストにすでに含まれてたら…ってのはng)だけ取り出したいんだけど、
この重複してないデータの取り出し方法がわかりません
どんな方法ありますか?
2023/01/25(水) 00:04:00.77ID:Eu1oQ2MW0
>>786
Python不得意ならExcelでやればいいんでは?
テキストファイル化してコマンドラインからuniq(PowerShellならGet-Unique)でもええし
Pythonならset(集合)にデータをタプルで入れていけば勝手に一意にはなる
2023/01/25(水) 01:26:29.91
#エクセルデータをpandasで読み込んでdataframeに変換する例
import pandas as pd
data = pd.read_excel('path/to/excel_file.xlsx')
#特定のシートだけ読み込む
data = pd.read_excel('path/to/excel_file.xlsx', sheet_name='Sheet1')
#特定の範囲だけ読み込む
data = pd.read_excel('path/to/excel_file.xlsx', usecols='A:C')
#読み込んだあと、特定の列から重複しないユニークな値を抽出する
data = pd.read_excel('path/to/excel_file.xlsx')
unique_values = data['column_name'].unique()

#pandasで重複しない値を取得する例
import pandas as pd
data = {'Name': ['John', 'Mike', 'Brad', 'Jane', 'John', 'Mike'],
'Age': [25, 30, 35, 40, 25, 30],
'City': ['New York', 'Los Angeles', 'Chicago', 'Houston', 'New York', 'Los Angeles']}
df = pd.DataFrame(data)
unique_values = df['Name'].unique()
print(unique_values)
2023/01/25(水) 01:50:21.75ID:u8Mn4x2gM
>>786
重複排除じゃなくて
最初から完全に一意のものだけ取り出すってこと?
俺の頭では無理だな
790デフォルトの名無しさん (ワッチョイ cf46-l+ta)
垢版 |
2023/01/25(水) 02:54:09.95ID:na5kNBW00
>>786
仕様の「リスト」が何を指すか解らない。その一文を無視して、

連想配列(Pythonだとdic?)で、
var["データの1要素"]++
みたいなことをし、
var["データの1要素"] != 1 を捨てるかな。
2023/01/25(水) 03:11:17.39ID:4wQ5Uou30
>>786
動的計画法で探索したら済む
2023/01/25(水) 08:15:31.51ID:ByQxjYtpa
Ruby 2.7 から、tally で、配列内に同じ要素が何個あるかを数えられる。
そこから、重複していないものをフィルターする

ary = [ 1, 2, 2, 1, 3 ]
p hash = ary.tally #=> {1=>2, 2=>2, 3=>1}

p result = hash.select { |key, val| val == 1 } #=> {3=>1}
2023/01/25(水) 09:28:21.85ID:1X933CFM0
既にexcelにあるなら、重複の削除でいいのでは
2023/01/25(水) 13:48:53.45ID:lTdR++oJ0
>>786
collections.Counterで要素数が1のものだけ抽出すれば?
2023/01/25(水) 13:53:44.39ID:lTdR++oJ0
こんな感じで。
import collections
l = ['a', 'a', 'a', 'a', 'b', 'c', 'c']
c = collections.Counter(l)
print([k for k,v in c.items() if v==1])
2023/01/25(水) 13:56:42.38ID:lTdR++oJ0
つか、ここだとmarkdown使えんから
具体的な質問なら、SOとか寺にしたほうがいいよ
2023/01/25(水) 15:23:19.30ID:B2re/Hy6d
というか>>1見ましょうって話だけど
2023/01/25(水) 22:08:02.33ID:BPa0NAyM0
>>795
上にもあるけど単にリストのユニーク要素を取り出すならsetに一旦変換するのが楽だと思うけど
l = ['a', 'a', 'a', 'a', 'b', 'c', 'c']
print(list(set(l)))
ただ>>786のやりたいことがイマイチ分からないのでみんなエスパーするしかない
エクセルが間に挟んだのはどういう処理(過去保存データとのマージとか途中経過置きたいのか)とかリストって一次元のリストなのかとかがよく分からない
2023/01/25(水) 23:56:04.30ID:3IYN0s1Ra
分割統治法の処理に一行追記するだけでできる気が
800デフォルトの名無しさん (ワッチョイ 5346-l+ta)
垢版 |
2023/01/26(木) 00:59:27.75ID:rjz6yl2y0
>>798
>>786
1:abcd
2:abcd
3:efgh
を、
1:abcd
2:efgh
とユニークにするのでなく、
1:efgh
としたいと言っているのでなかろうか。どうだろう。
2023/01/26(木) 12:21:48.66ID:M4fxvzOfM
新規性探索アルゴリズムで実装してみてはどうだろう
2023/01/26(木) 12:31:06.80ID:GrZTDGimd
おそらく探索系のアルゴリズム使うよりもfind等の関数型でやったほうが強いだろう
rubyならすぐ書けるんだがな
2023/01/26(木) 12:43:57.64ID:UdXClMFA0
数が一つを保証するために探索系アルゴリズムもないだろう
N個あったらO(N)で数え上げだろう
804デフォルトの名無しさん (ブーイモ MMff-3swV)
垢版 |
2023/01/26(木) 16:56:31.08ID:T1n7nFq3M
30代Pythonクソチョン男は強姦魔の犯罪者!
あなたの近くにいます!
父母と祖父母の戸籍謄本を提出させましょう!
2023/01/26(木) 22:54:11.42ID:Wh8CZgs50
ZDDを
2023/01/27(金) 16:28:22.40ID:uGmwFOSM
これ地味にむずいかもって事例に遭遇した。

ページネーションされているウェブサイトにて
1ページ毎に(日付、値)の形式で何行か表示されていて
(日付、値)だけをスクレイピングするとする

例えばこんな感じ
1ページ目
2023/01/26(木) 22:54:11、1
2023/01/26(木) 22:53:30、2
2023/01/26(木) 22:52:08、1
2ページ目
2023/01/26(木) 22:51:04、1
2023/01/26(木) 22:51:04、2
2023/01/26(木) 22:50:23、1

問題は、
スクレイピング中に、ウェブサイト側がデータを更新した場合
同じ日付を重複して収集してしまう可能性があること。
同じ日付時刻なこと自体は間違いではなく正常なので
ウェブサイトの更新時によるズレなのか、単に同じ日付時刻のデータなのか
を判別する処理が難しいというか、単純であればあるほど
常に最新データを収集するとかでない限り不可能な気がした
807デフォルトの名無しさん (オイコラミネオ MM07-M8KT)
垢版 |
2023/01/27(金) 16:47:43.59ID:c/fSkYwsM
>>1
svgを使いたいのだが、
インストールすらエラー、、、
2023/01/27(金) 17:16:38.85
google colabは普通にできた >>807
https://colab.research.google.com/drive/1lXnjIZ29Dv52Xxqms_Bq72set8w_gNFp
809デフォルトの名無しさん (ブーイモ MM1f-/qsW)
垢版 |
2023/01/27(金) 17:38:27.29ID:COYgsLLDM
>>806
識別子も更新日時もなくサイレントに更新されるような品質の低いデータならページ単位に取得日時を記録してスナップショットとして割り切るしかない
2023/01/27(金) 19:13:48.24ID:ttcy9Q0Rd
>>806
スレタイ読める?
811デフォルトの名無しさん (オイコラミネオ MM07-M8KT)
垢版 |
2023/01/27(金) 19:53:07.73ID:wbJwBZC+M
>>808
ありがとうございます
812デフォルトの名無しさん (ワッチョイ 43ad-qYbV)
垢版 |
2023/01/27(金) 22:54:09.27ID:QwmTjMRl0
>>806
Rakuten Koboの期間で絞り込むと一緒だ
デフォルトが売上順になっていて、ページ移動すると、順番が変わる
結果セットに対して、ページを作成しているのではなく、その都度作成してる。
こうゆう作りの所は、諦めるしかない。
結果セットをいじるのは、勘弁してほしい
(今日出ているのに、ページまたがりで見つからなくて、別のとこで買ったことも)
2023/01/27(金) 23:03:53.86ID:wC9qLVMj0
気持ち悪い自演
814デフォルトの名無しさん (ブーイモ MMb6-Db9z)
垢版 |
2023/01/29(日) 11:45:29.18ID:Ac+ianrsM
30代Pythonクソチョン男は強姦魔の犯罪者!
あなたの近くにいます!
父母と祖父母の戸籍謄本を提出させましょう!
2023/01/29(日) 14:25:12.72ID:sXEwsNxr
pythonファイルを定期実行するときに、○○秒待機したタスクだけを一度実行(また○○秒待機)
ってこんな面倒だったっけ・・?
https://ideone.com/s6VVQo
whileで無限ループとかだと、経過時間をメモリできるから簡単だけど
pyファイル実行毎だとその都度全部クリアされるからどこかに記録しとかないといけない、という認識であってるのだろうか・・
ほぼ最小構成のつもりでこんなに長くなってしまった
2023/01/30(月) 15:47:46.06ID:6GqSWy3Oa
>>815
普通の人はscheduleモジュール使う
プロセスごとだとLinuxのcronやWindowsのスケジューラ使う
2023/01/30(月) 17:17:45.74ID:U0BG6clG
プロセスごとだと、タスクごとにpyファイルを分けて
例えば
task1.py task2.py ・・・
みたいに分けて
OSの方でそのpyファイルを定期実行する感じですかね

仮に、どこからか情報を取得するようなタスクだったら、DBに記録して
DBから情報を取得して処理する.py
に分けて、それも定期実行する
みたいな
もちろんやり方は自由なんだろうけど
実行時間に依存した料金体系のサービスで節約したい場合とか
ループ使わないだけで構成変わっちゃうので、かつ汎用性持たせようとして苦労してます・・
ありがとうございました >>816
2023/01/30(月) 19:13:50.35ID:6GqSWy3Oa
>>817
金額が安いのはサーバレスサービスかな
例えばhttpで受け付けるAPIを用意して、AWSでLambdaファンクションをCloudWatch経由でたたく
1分に1回実行するとして2000円以下だと思う
それも高いと言うなら月額1000円未満のVPS借りてLinuxでcronかな
819デフォルトの名無しさん (ワッチョイ 3635-5T4A)
垢版 |
2023/01/31(火) 14:03:50.00ID:F8VbnJh50
https://github.com/fanzeyi/pokemon.json/blob/master/pokedex.json
*火(Fire)と飛翔(Flying)の属性を持ったポケモンの数を表示
*消防士向きのポケモンを判定する  図鑑番号を指定して  水(Water)のタイプをもっていて、すばやさが平均以上の  ポケモンであれば、採用と表示する
*発電向きのポケモンを判定する  図鑑番号を指定して  でんき(Electric)のタイプをもっていて、ぼうぎょりょくが中央値以上の  ポケモンであれば、採用と表示する
誰かこれの回答と解説お願いできる?
820デフォルトの名無しさん (ワッチョイ 3635-5T4A)
垢版 |
2023/01/31(火) 14:04:37.72ID:F8VbnJh50
import urllib
import json
response = urllib.request.urlopen('https://raw.githubusercontent.com/fanzeyi/pokemon.json/master/pokedex.json')
content = response.read()
jpk = json.loads(content)
jpk
821デフォルトの名無しさん (ワッチョイ 3635-5T4A)
垢版 |
2023/01/31(火) 14:05:09.66ID:F8VbnJh50
頼む
822デフォルトの名無しさん (ワッチョイ 4ea4-5T4A)
垢版 |
2023/01/31(火) 14:41:57.01ID:M1DmxzTw0
PySimpleGUIで2つの最大サイズの画面を遷移させたいのですが、
ウインドウを作成しておいて表示/非表示で見た目に入れ替えようとしました。

# 最初にウインドウの起動位置を指定して起動
main_window = make_main(0, 0)
sub_window = make_sub(0, 0)
# サブウインドウを非表示にする
sub_window.hide()

main_windowにあるボタンを押すと
# サブウインドウを表示する
sub_window.un_hide()

サブウインドウが最前面に表示されます。
その後、sub_windowにあるボタンを押して、
# サブウインドウを非表示にする
sub_window.hide()
メインウインドウを最前面にしようとしてもサブウインドウが最前面に表示されたままです。

双方のボタンで前後入れ替えて表示したいのですが、良い案はありませんでしょうか。
2023/01/31(火) 15:06:40.46
AIに聞いた結果 >>819
合っているかはわからん

import urllib
import json
import pandas as pd
response = urllib.request.urlopen('https://raw.githubusercontent.com/fanzeyi/pokemon.json/master/pokedex.json')
content = response.read()
jpk = json.loads(content)
#print(jpk)
df = pd.DataFrame(jpk)
df['name']=df['name'].apply(lambda x: x['japanese'])
df=df.join(df["base"].apply(pd.Series)).drop(columns=["base"])

#火(Fire)と飛翔(Flying)の属性を持ったポケモンの数を表示
target_types = ['Fire','Flying']
count = sum([all(value in row for value in target_types) for row in df['type']])
print("typeがFireとFlyingのポケモンの数",count)

#消防士向きのポケモンを判定する  図鑑番号を指定して  水(Water)のタイプをもっていて、すばやさが平均以上の  ポケモンであれば、採用と表示する
target_types = ["Water"]
m_speed=df["Speed"].mean()
filtered_df = df[df.apply(lambda row: all(value in row['type'] for value in target_types) and row['Speed'] >= m_speed, axis=1)]
print("消防士向きのポケモン\n",list(filtered_df["name"]))
#発電向きのポケモンを判定する  図鑑番号を指定して  でんき(Electric)のタイプをもっていて、ぼうぎょりょくが中央値以上の  ポケモンであれば、採用と表示する
target_types = ["Electric"]
m_defense=df["Defense"].median()
filtered_df = df[df.apply(lambda row: all(value in row['type'] for value in target_types) and row['Defense'] >= m_defense, axis=1)]
print("発電向きのポケモン\n",list(filtered_df["name"]))

#typeがFireとFlyingのポケモンの数 6
# 消防士向きのポケモン ['カメックス', 'ゴルダック', 'ニョロモ', 'ニョロゾ', 'ニョロボン', 略
# 発電向きのポケモン ['コイル', 'レアコイル', 'マルマイン', 'サンダー', 'デンリュウ', 'ライコウ', 略
2023/01/31(火) 15:11:42.84
>>822
PySimpleGUI の bring_to_front() 関数を使って、ウインドウを最前面に表示することができます。

以下は、サブウインドウを最前面に表示する例です:
sub_window.un_hide()
sub_window.bring_to_front()

また、メインウインドウを最前面に表示するには、以下のようにします:
main_window.bring_to_front()

このように、各ウインドウを最前面に表示することで、ボタンを押したときに前後入れ替えて表示することができます。
825デフォルトの名無しさん (ワッチョイ 4ea4-5T4A)
垢版 |
2023/01/31(火) 15:22:58.11ID:M1DmxzTw0
>>822
出来ました、ありがとうございます!
全画面表示しかしていないので、もしかして表示/非表示にする必要は無いかもですね。
826デフォルトの名無しさん (ワッチョイ 3635-5T4A)
垢版 |
2023/01/31(火) 15:30:49.11ID:F8VbnJh50
>>823
多分あってます、ありがとうございます!
827デフォルトの名無しさん
垢版 |
2023/01/31(火) 15:43:13.04
>>823,>>819
>水(Water)のタイプをもっていて、すばやさが平均以上
>でんき(Electric)のタイプをもっていて、ぼうぎょりょくが中央値以上
全水タイプの素早さの平均値
全でんきタイプのぼうぎょりょくの中央値、なら

#消防士向きのポケモンを判定する  図鑑番号を指定して  水(Water)のタイプをもっていて、すばやさが平均以上の  ポケモンであれば、採用と表示する
target_types = ["Water"]
new_df=df[df['type'].apply(lambda x: all(value in x for value in target_types))]
m_speed=new_df["Speed"].mean()
filtered_df = new_df[new_df.apply(lambda row: all(value in row['type'] for value in target_types) and row['Speed'] >= m_speed, axis=1)]
print(f"消防士向きのポケモン: {len(filtered_df)}\n",list(filtered_df["name"]))
#発電向きのポケモンを判定する  図鑑番号を指定して  でんき(Electric)のタイプをもっていて、ぼうぎょりょくが中央値以上の  ポケモンであれば、採用と表示する
target_types = ["Electric"]
new_df=df[df['type'].apply(lambda x: all(value in x for value in target_types))]
m_defense=new_df["Defense"].median()
filtered_df = new_df[new_df.apply(lambda row: all(value in row['type'] for value in target_types) and row['Defense'] >= m_defense, axis=1)]
print(f"発電向きのポケモン: {len(filtered_df)}\n",list(filtered_df["name"]))
#typeがFireとFlyingのポケモン 6 ['リザードン', 'ファイヤー', 'ホウオウ', 'ヒノヤコマ', 'ファイアロー', 'オドリドリ']
#消防士向きのポケモン: 65
#['カメックス', 'ゴルダック', 'ニョロモ', 'ニョロゾ', 'ニョロボン', 略
#発電向きのポケモン: 27
#['コイル', 'レアコイル', 'マルマイン', 'サンダース', 'サンダー', 'デンリュウ', 'ライコウ', 略
2023/01/31(火) 16:34:08.98ID:yVHAxCVq0
いつまでここにコード貼り付けてるんだ?
>>1が読めないのか?
2023/01/31(火) 16:38:55.16ID:s5HjvgLO
fastAPIのこれが謎技術すぎて理解が追いつかない
https://sqlmodel.tiangolo.com/tutorial/fastapi/session-with-dependency/
要約すると
def db_session():
 with Session(engine) as session:
  yield session
session=Depends(db_session)
session.add(...)
session.add(...)
的にコードはwith構文の外に書いているのに、処理はwith内で書いたときのような効果が維持されてる(with抜けるときに勝手にsession.close()してくれるなど)、みたいな
from fastapi import Dependsってクラスか何かを通してるみたいで
https://github.com/tiangolo/fastapi/blob/master/fastapi/dependencies/utils.py
この辺ぽいけど見たけどよくわからなかった
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況