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
2022/12/30(金) 12:34:35.19ID:6lQGRZJ+d
>>339
デコレータとは、@decoの形で使用されることを想定している関数
ただそれだけのこと
341デフォルトの名無しさん (ササクッテロリ Spef-0zvw)
垢版 |
2022/12/30(金) 12:39:12.89ID:EYlolZ9wp
>>340
def deco (fn):
print("Good")
fn()
print("Good")

と↑をラップした↓

def outer (fn):
def deco ():
print("Good")
fn()
print("Good")
return deco

だとそれぞれどういうメリットデメリットが想定できる?
この程度だったら何も変わらない?
2022/12/30(金) 14:25:39.66ID:v4ysyuF5a
>>341
前者はデコレータとして使用できない
後者は使用できる
それだけのこと
343デフォルトの名無しさん (ササクッテロリ Spef-0zvw)
垢版 |
2022/12/30(金) 14:30:10.80ID:CAw5d3+3p
>>342
前者もデコレータとして使えるよ?
@decoで使うってことだよね?
344デフォルトの名無しさん (ササクッテロリ Spef-0zvw)
垢版 |
2022/12/30(金) 21:59:47.08ID:i0HtXYTfp
>>343
自己解決しました
345デフォルトの名無しさん (ブーイモ MMf3-pLDh)
垢版 |
2022/12/30(金) 22:26:59.27ID:XgQsZPRMM
自己解決とは一体・・・ww
346デフォルトの名無しさん (ササクッテロリ Spbb-3X/C)
垢版 |
2022/12/31(土) 00:05:03.98ID:Y1CGuIqUp
>>345
自分のわかっていないところがわかりました
2022/12/31(土) 00:20:01.24ID:E+Koymh80
replitのpythonテンプレートを使っているのですが、実行すると勝手にパッケージをインストールしたりします。これを止める事は出来ますか?
2022/12/31(土) 00:20:01.95ID:E+Koymh80
replitのpythonテンプレートを使っているのですが、実行すると勝手にパッケージをインストールしたりします。これを止める事は出来ますか?
2022/12/31(土) 14:58:09.42ID:iYLc9PIz
main.pyのソースを見たときに
import ○○ #upm package(パッケージ名)
の行のコメントアウト外すと消えるかも>>348
2023/01/01(日) 18:58:07.86ID:QkrDyXxA0
ワークマンの売上高は10年で2.6倍 好調の背景に何があるのか
www.itmedia.co.jp/business/articles/2301/01/news011.html

ワークマンpythonらしいぞ
まーそうなるわな
2023/01/01(日) 19:36:11.17ID:ps54Dm7d0
スレチだけど...
> KPIを達成しても売り上げが伸びない場合、社員ではなく経営の責任ということになります。
> 『会社がやれと言った内容がそもそも間違っていたんだね』ということで
まあインタビュー記事だからいくつか盛ってるとは思うけどこれがそれなりでも浸透してるなら確かに強いと思うわ
352デフォルトの名無しさん (ブーイモ MMb6-DakT)
垢版 |
2023/01/01(日) 21:38:32.18ID:OSWb6iEUM
>>350
ぶっちゃけ一番安上がりだからじゃね?
2023/01/01(日) 22:00:13.33ID:UVAQFgfk0
ちょっと前のすれにtypecheckerが出てたけど、
仕事で静的型付けって意識してる?
Dropboxが静的型付け使って開発してるぜ~っていう記事を
ちょうど見かけたもんで。
https://navi.dropbox.jp/our-journey-to-type-checking-4-million-lines-of-python
2023/01/01(日) 22:16:25.00ID:2lDDSA+U0
実際には型が動的で有り難いことは殆どなくて、大抵は決まったものしか入らない
だからこそ型なんか書かなくていい、という思想な気がする
2023/01/01(日) 22:41:34.82ID:65g2Zgvwd
>>353
typing hint(+dats class) 、mypyももちろんオン。会社など複数人が関わるプロジェクトね。一人なら好きにやれば良い
356デフォルトの名無しさん (アウアウエー Sa52-9yt5)
垢版 |
2023/01/02(月) 12:12:57.71ID:XEDAh58aa
Windows環境で、「アプリと機能」の一覧に表示されるソフトウェア名一覧をPythonから取得するにはどうしたら良いですか??

https://tadaup.jp/loda/0102120639918904.png
2023/01/02(月) 12:15:15.36ID:a90VB+UOd
レジストリ読む
2023/01/02(月) 14:11:49.16ID:VCjQSWZY0
WMI
2023/01/02(月) 17:01:40.21ID:mMdAew+l0
ChatGPTで答えさせて3つ出したコードのうちwmic使ったものを手直ししてみた
デコードをutf-8だったのをcp932にしたり文字列の整形あたりを改変しなきゃだったけどこういうとき結構良い答え持ってくる

Windows環境で、「アプリと機能」の一覧に表示されるソフトウェア名一覧をPythonから取得するにはどうしたら良いですか??

Windowsで「アプリと機能」の一覧を取得するには、次のような方法があります。

wmic コマンドを使用する
Windows Management Instrumentation (WMI) を使用する
PowerShell を使用する
以下は、いずれの方法もPythonから実行するための例を示します。

import subprocess
result = subprocess.run(['wmic', 'product', 'get', 'name'], stdout=subprocess.PIPE)
output = result.stdout.decode('cp932')
applications = [line.strip() for line in output.split('\n')]
for app in applications:
print(app)
360デフォルトの名無しさん (スッププ Sdba-9yt5)
垢版 |
2023/01/02(月) 19:23:19.67ID:gNyrLSWLd
>>359
すごい!ありがとうございます!
2023/01/02(月) 19:38:51.68ID:qfqFAF6wa
>>359
サンプルが少ないからほぼ直コピペなんだろうな
2023/01/02(月) 20:50:28.36ID:xWUsdzOR0
自演はいいって
2023/01/02(月) 21:06:38.35ID:gHhSLzFgM
すごくいいです
2023/01/02(月) 21:08:42.90ID:9G/14EFS0
subprocessの書き方古くない?
2023/01/02(月) 21:18:09.07ID:xWUsdzOR0
いやrunは新しいAPIだよ
2023/01/02(月) 21:20:08.80ID:9G/14EFS0
cmdを起動せずにリストを渡すのと、cmdにコマンドの文字列渡すやり方があるよね
2023/01/02(月) 21:30:45.62ID:xWUsdzOR0
文字列渡すパターンは危険だからね
チェックをちゃんとしないと予期せぬコマンドが実行される
shell=Trueしてると特にやばい
2023/01/02(月) 21:32:02.96ID:9G/14EFS0
別にリストでも変わらないと思うけど
面倒なだけで
2023/01/02(月) 21:36:28.26ID:1k7qyNCA0
>>364
新しい書き方教えて
2023/01/02(月) 21:38:52.52ID:9G/14EFS0
時系列はよく知らんけど、リストで渡す方法がまずあって、
不便だからと文字列の方法が追加されたんじゃないの?
2023/01/02(月) 22:12:07.01ID:65aHjL4I0
shlex.split("date +%a")
# -> ["date", "+%a"]

run に渡すリストはこうやって作ると便利だよ (´・ω・`)
2023/01/02(月) 22:23:15.59ID:9G/14EFS0
普通にf文字列がいい
2023/01/02(月) 22:47:14.11ID:+OShonpv0
ModuleNotFoundError: No module named 'xml.etree'; 'xml' is not a package

ElementTreeでXMLを作成すると上のエラーがどうしても出てしまいます。
ElementTree以外にXMLがいじれるのって何がいいですか?
BeautifulSoupですか?
2023/01/02(月) 23:55:25.20ID:VCjQSWZY0
xml.pyかxmlなディレクトリがあるんちゃうか
ググっても同じこと書いてる記事多数
2023/01/03(火) 00:26:25.58ID:o2Yi6Z0r0
>>374
レスありがとうです。その記事を見て確認したんですけど特に問題はなく、それ以外の解決法も見当たらずでお手上げ状態です
2023/01/03(火) 00:37:01.34ID:hRecP/5n0
エラーが出ますは自力で解決しろとしか
ただの間違いなんだから
2023/01/03(火) 02:55:11.90ID:LZW0ef8O0
誰もやらないと思うけど
こんな感じのエスケープだと、失敗してしまう
(コマンドプロンプトやshell=Trueだと、成功する)

C:¥"Program Files"¥Python¥python.exe -V
2023/01/03(火) 06:11:34.42ID:cXTWG1PB0
そりゃ " " を剥ぎ取るとかは c m d.exe がやってるんだからそれを食わせたいなら同じ事をしてやらないと失敗するのは当たり前
2023/01/03(火) 09:57:15.62ID:LZW0ef8O0
文字列で渡すときはWinAPIのCreateProcessを見てね
って、書いてあったわ
実行ファイルの解釈から違うとは思わなかった
すまん
2023/01/03(火) 15:48:59.80ID:E/lRcWz50
ファイル名の取得という基礎の基礎が
ようやく安定したレベルですまない。

import glob
files = glob.glob("./images/**", recursive=True)
print("recursive", files)

フォルダ直下にjpgファイル21個のみ入っている場合、結果が、

recursive [1.jpg 2,jpg,〜,21.jpg]
と横長に表示されると思う。

これをExcelに貼り付けたときも同じかな。
これを縦に表示させることってできる?

recursive[
1.jpg,
2.jpg,
|
21.jpg]

みたいなイメージで結果を出力したい。

そもそもできることなのか分からないけど、
素直にWordに貼り付けて、
カンマを特殊文字で改行に置き換えた方がはやいかな?
381デフォルトの名無しさん (ブーイモ MMba-DakT)
垢版 |
2023/01/03(火) 16:00:07.29ID:xk3Wdt8AM
>>380
“\n”.join(files)
2023/01/03(火) 16:04:23.85ID:HKIHgf/70
globはいろいろ謎だよな
歴史的な何かとの互換性で微妙に使いにくい
2023/01/03(火) 16:06:39.39ID:HKIHgf/70
とりあえず、import glob はやらなくて、
from pathlib import Path
p = Path("./")
for file in [str(x) for x in p.glob("*")]:
 print(file)
みたいに使ってるけど、これでもしっくり来ない
2023/01/03(火) 16:15:41.39ID:97qfA6UK0
自分でフィルタしたいならos.walk
2023/01/03(火) 16:25:05.94ID:E/lRcWz50
>>381
ありがとう。
一見すると、単に","が"n"に変わっただけのように見えるけど、
Excelに貼り付けたときの挙動がまったく異なるんだね。

しかし検索してもアフィみたいなサイトしかなくて大変だな
入門書探してみるノシ
2023/01/03(火) 17:15:05.41ID:90wq8UOz0
\nただの改行だよ
2023/01/03(火) 18:00:04.32ID:E/lRcWz50
失礼。

print("\n".join(files))

こういうことね。
388デフォルトの名無しさん (ワッチョイ 5b2c-Hg2a)
垢版 |
2023/01/03(火) 22:20:57.30ID:dIZcTCs/0
定期的に
tuple[str, tuple[int200個]] #key: valueです
を1万件取得して
既存の辞書に追加、更新していきます
このときkeyがなければkey, valueを登録するのはいいとして

keyが既存のときのvalueの更新はどうするのが常道ですか? 高速なのがいいです。または不要な書き換えがないほうがいいです
valueに差異があれば書き換え がいいのか、問答無用で全部更新しちゃうべきなのか…
2023/01/03(火) 22:55:20.83ID:97qfA6UK0
理解も進むしベンチとるのがいいよ
すでに新しいタプルを構築してるなら問答無用でいいと思うけどね
キーの確認や差異がないかしらべるコストもゼロじゃないし
2023/01/03(火) 22:58:56.25ID:n4oKw/VOa
データベースで言う、upsert だろ。
データが無ければinsert、有ればupdate

基本中の基本
391デフォルトの名無しさん (ブーイモ MM7f-UGA+)
垢版 |
2023/01/04(水) 01:07:35.19ID:O+gUhHpWM
30代Pythonクソチョン男は強姦魔の犯罪者!
あなたの近くにいます!
父母と祖父母の戸籍謄本を提出させましょう!
2023/01/04(水) 08:56:21.55ID:fFs0aGwQ0
perlから来るとkeyが既にあるか無いか気にしないといけないdictがうざくて仕方ない
393デフォルトの名無しさん (ワッチョイ f397-HbQu)
垢版 |
2023/01/04(水) 10:43:47.27ID:xfkX5cN10
dictを継承したmydict作って、setitemをオーバーライドすればいいんじゃない?なんかその辺のパッケージにありそうだけど
2023/01/04(水) 11:09:24.58ID:fFs0aGwQ0
autovivificationは便利だけどどう考えても邪悪なのでpythonには似合わないとは思う
多次元のdictとか何も考えずに作れて楽なのに
395デフォルトの名無しさん (ワッチョイ cebb-FKhm)
垢版 |
2023/01/04(水) 11:54:12.95ID:3yoX2IMb0
perlから来たからdefaultdictを知らないってことか
396デフォルトの名無しさん (ブーイモ MM13-DakT)
垢版 |
2023/01/04(水) 11:57:20.58ID:PRI0tLaEM
defaultdictとか関係なくないか?
単にfoo[key] = valueってしてけばいいだけの話じゃないの?
2023/01/04(水) 12:17:46.09ID:fFs0aGwQ0
文章に単語が何回登場したかカウントする
みたいなことをしたい時に、
if word in count:
 count[word] += 1
else:
 count[word] = 1
みたいに毎回判定が入る

perlなら問答無用に
$count[$word] += 1;
で済んでしまう
2023/01/04(水) 12:21:49.86ID:fFs0aGwQ0
で、この場合はdefaultdictで解決できるのだけれど、
そうも行かないケースがままある
399デフォルトの名無しさん (ワッチョイ cebb-FKhm)
垢版 |
2023/01/04(水) 12:27:21.02ID:3yoX2IMb0
そうもいかないケースを挙げてみ?
2023/01/04(水) 13:21:09.09ID:hHvDsnQT0
俺はこっち派

count[word] = count.get(word, 0)+1
401デフォルトの名無しさん (ブーイモ MM26-DakT)
垢版 |
2023/01/04(水) 14:05:48.69ID:hsLqwQpIM
>>397
質問とは関係ない話だったのか

defaultdictをわざわざ使わなきゃいけないのは面倒だとは思うがパフォーマンスに影響するところだから違うものとして分ける考え方も理解できる
402デフォルトの名無しさん (ワッチョイ 0e30-9yt5)
垢版 |
2023/01/04(水) 16:11:58.90ID:Y9cKLIFN0
>>397
いいんじゃないの
上に書いてる奴は見れば一瞬で理解できる
2023/01/04(水) 16:31:04.37ID:nnn7+JHJ0
perlの糞文法の轍を踏まず、perl屋さんが億劫に感じる方向でおながいしまつ
404デフォルトの名無しさん (アウアウウー Sac7-Dewi)
垢版 |
2023/01/04(水) 16:33:02.89ID:s5vEki4Ca
そりゃ言語が違うんだから当たり前だろ
そんなにperlが好きなら一生perl浸かってろ
2023/01/04(水) 16:46:54.88ID:169GBKXC0
Perlはこそっと使え
決して異教徒の目に触れさせるな
2023/01/04(水) 17:03:28.83ID:fFs0aGwQ0
初期化してない変数をいきなり参照したら0で構わないと思うんだけどな
99%はバグってるんじゃなくて初期化を忘れただけなんだから
2023/01/04(水) 17:46:01.10ID:R0FkSoR+6
バグの原因を初期化忘れだけに絞れるなら恩恵としては大きいな
2023/01/04(水) 18:04:46.20ID:lFNs7lW+0
>>406
> 99%はバグってるんじゃなくて初期化を忘れただけなんだから
根拠の無い妄想はブログとかでやってくれ
2023/01/04(水) 18:08:36.66ID:hHvDsnQT0
>>406
99%は言い過ぎ
2023/01/04(水) 18:23:39.40ID:fFs0aGwQ0
関数内の0や""で初期化してる処理を、スコープ先頭に移して挙動が変わるかどうか
変わらないならそれは省略可能だった初期化
2023/01/04(水) 18:23:43.29ID:oLi3mo910
>>406
そこはNoneでいいだろ。つか、初期化してなきゃ型も決まらないから0にもしようがない。
2023/01/04(水) 18:50:16.06ID:fFs0aGwQ0
だからこその動的型付けで、0だったことにする
文字列として参照されてたら""だったことにする
dictとして参照されてたら{}だったことにする
2023/01/04(水) 18:53:52.08ID:rMcGd+esd
>>412
それ別のバグ生み出しそう
型の違いって致命的じゃね
2023/01/04(水) 19:06:24.67ID:oLi3mo910
>>412
数値として参照されたか文字列として参照されたかってどう判断するつもり?
2023/01/04(水) 19:09:25.07ID:fFs0aGwQ0
perlはそのへんを、お前は人工知能か何かなのかという精度で判定してくれてた
普通に考えると確定しないようなケースでも何故か正解する
失敗すると発見不可能なバグになるから封印したんだろうな
2023/01/04(水) 20:10:19.57ID:JBcAh0Lfd
rubyキチガイといいこいつといい多言語は~って奴は聞いてもないこと話してきてウザい
2023/01/04(水) 21:31:42.96ID:oLi3mo910
そりゃperlと同じようなコンテキストの考え方を導入しなきゃ無理だな。
少なくとも、数値の加算と文字列の連結に同じ'+'演算子を使ってるpythonは
そのへん全部ひっくり返さないとならない。
2023/01/04(水) 21:39:33.83ID:fFs0aGwQ0
+される相手が文字列なら文字列
2023/01/04(水) 21:48:59.92ID:QnXxsDbw0
Option Explicit On
なんてやったら阿鼻叫喚か
2023/01/04(水) 22:01:32.73ID:lFNs7lW+0
>>418
両方初期化してない変数ならどうするんだ?
2023/01/04(水) 22:08:13.33ID:169GBKXC0
降魔の儀式を始める
2023/01/04(水) 23:09:43.15ID:fFs0aGwQ0
a = b + c
でbもcも未初期化なら、aも未初期化で何も困らない
2023/01/04(水) 23:58:47.37ID:PU4coe7B0
初期化すべきなのに忘れていて
忘れたものを忘れたまま使おうという発想が理解できない
そんなコードもコーダーも使い物にならない
2023/01/05(木) 00:00:28.67ID:UaHb0F9a0
>>417
呼ばれるメソッドはちがうよ割と大昔から
https://docs.python.org/ja/3/reference/datamodel.html?highlight=__add__#emulating-numeric-types
2023/01/05(木) 00:03:39.00ID:/79BsoYR0
>>422
そりゃ結局None。
変数の初期化はこの際関係なくて None + int -> int で None + str -> str になってほしいってことなんだろ。
2023/01/05(木) 00:05:55.35ID:/79BsoYR0
>>424
左辺の型が決まらないことには呼びようがないんじゃね?
2023/01/05(木) 07:49:37.10ID:DuFbe6wEd
Perl好きならPerl使ってろよ
2023/01/05(木) 08:03:01.51ID:0egeTroNM
いい加減perlおぢさんウザイな
荒らしてるという自覚は無いんだろうな
2023/01/05(木) 08:37:29.48ID:MKhVdLEmr
頭がPerl
2023/01/05(木) 08:54:26.68ID:qYGcpxae0
おっぱいがPython
2023/01/05(木) 08:54:31.46ID:XvyJyDBe0
暗黙より明示のルールに反してるから可能だとしてもやらないだろう

変数を参照するだけか書き換えもするかで名前空間が変わるのは結構暗黙的だと思うけど、
それは利便性が優先した
初期化を省略するのはそんなに利便性が無い
2023/01/05(木) 08:57:08.87ID:O+NRT3S+0
利便性が無いというかタイプミスを検出できなくなるから
2023/01/05(木) 13:08:24.65ID:A7vAZ1Ex0
ミスはしませんw
2023/01/05(木) 13:28:28.85ID:XvyJyDBe0
タイプミスしたら使ってない変数が現れるんだから、それは簡単に検出できる
2023/01/05(木) 14:43:39.73ID:O+NRT3S+0
>>434
どうやってやるの?
2023/01/05(木) 14:53:37.34ID:XvyJyDBe0
チェッカーにかける
2023/01/05(木) 16:58:05.12ID:Ej4/aJA/0
str型限定だけど、型を自動的に変更してくれるというのはちょっとありがたいかも
format()やf文字列だと、変数をそのまま突っ込めばいいので楽ちん
2023/01/05(木) 17:05:39.43ID:DbVL8BP10
自動変換は悪さにしか使われないという印象だからいらないかな
perlみたいに言語がよしなにやってくれるならそれで良いけど
ユーザー定義の暗黙の型変換は間違いなく地獄
2023/01/05(木) 17:13:54.28ID:/79BsoYR0
C++の変換コンストラクタとかな。
自分でそれを意図して書く人にとってはそのときは楽だろうけど、後から読む人が大変。
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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