くだすれPython(超初心者用) その49【まず1嫁】

■ このスレッドは過去ログ倉庫に格納されています
2020/07/18(土) 16:33:27.37ID:/iWSRGfH
当スレに★Python以外のプログラミング言語での回答類を書くべからず★
「Ruby では」「Rubyでは」「某言語では」をNGワード登録推奨

このスレッドは「お勉強」スレのほうには書き込めない超低レベル、
もしくは質問者自身何が何だか分からない質問を、勇気を持って書き込むスレッドです。
へび使いが優しくコメントを返しますので、お礼は Python の布教と初心者の救済をお願いします。

★エラーを解決したい場合は、
  表示されてるエラー全文(勝手に省略やスクショうp等の横着クソ行為禁止)と、
  実行環境(Pythonのバージョン・OS+IDEの種類とバージョン)をシッカリ書くこと。

【【【複数の連続半角スペースはなかったことになる・タブがうまく入らない5chの仕様】】】に注意!
Pythonの★ソースコードをそのまま5ちゃんにコピペすると、インデントが崩れてチヌ★ので
  ↓等の、いわゆるコードうp用サイトに貼ってこいください。
ttps://techiedelight.com/compiler/  Run Code機能あり。最近流行中?
ttp://ideone.com/      デフォ設定はC用のため言語選択ボタン押下がピコ手間かも。
ttp://codepad.org/      ほぼ直感的に使える。Run codeボタンあり。
ttp://pastebin.com/     まずまずシンプル。
ttp://dpaste.com/      とてもシンプル。消えるまでの日数は十分長ーく指定のこと。

◇Python公式サイト◇ http://www.python.org/
◇まとめwiki◇ ttp://python.rdy.jp/wiki.cgi

〇前スレ〇
くだすれPython(超初心者用) その48【まず1嫁】
https://mevius.5ch.net/test/read.cgi/tech/1589201940/

次スレは >>985 あたりが挑戦してくだしあ。(980過ぎても自動落ちはしなくなって久しい)
### END OF TEMPLATE ###
2020/08/11(火) 09:48:14.19ID:B3vzQThI
>> 532
これなぁ
チュートリアルはいい出来だと思うが、リファレンスとしては本当にひどい
2020/08/11(火) 09:57:17.26
ファイルの書き込みがダブルブッキングになりそうなときっていい感じに勝手にpython側で処理してくれるの?
2020/08/11(火) 10:01:47.77ID:B3vzQThI
>>539
やってみたら分かるけど、後にオープンしたほうが優先される
2020/08/11(火) 10:10:39.94
>>540
そもそもテストの仕方がわからないけどこれでええんやろか
with open('hoge.txt', mode='w') as f:
f.write('a')
with open('hoge.txt', mode='w') as f:
f.write('b')
with open('hoge.txt') as f:
print(f.read())

たしかにbだけしか更新されてなかった・・
つまりは同じファイルをアッチやコッチで更新してたときに
with open閉じるまでに処理が重なって同時更新した場合は、
後が優先され前のデータは書き込みできていないってことかー・・
2020/08/11(火) 10:34:21.08
と、おもったら上書きモード"w"になってただけだった
"a"だと普通に追記になったわ
上書き書き込み、というより、追記
がやりたいことだった >>539
追記のときもwith openがほぼ同時に処理されるなんてことはあるのだろうか
543デフォルトの名無しさん
垢版 |
2020/08/11(火) 10:40:31.12ID:x3iAuc4F
モジュールとクラスでは、モジュールのほうが大きいんですよね?
2020/08/11(火) 10:45:12.20ID:B3vzQThI
>>542
バッファリングがあるからそんなに単純じゃないよ
同時に処理されるかどうかは確率的にゼロでなければ長期間運用してたら起こる可能性はあるので、その可能性があるならバッティングの処理が必要
一般的な方法としては空のファイルを作ってそのファイルが存在するかどうかで判断する
他の方法としてはsyslogやデータベースを使って、その処理は既存の仕組みで対応する
2020/08/11(火) 10:53:49.16
>>544
sleepしてって考えてたけどsleep終わったあとに同時になったら・・とか思ってたが
>空のファイルを作ってそのファイルが存在するか
(これも存在確認後に、ってのがちょっと気になるが)
>syslogやデータベース
なるほど、あまり気にせず既存のを使えるのはいいな

とりあえずは余裕をもって確実に順次実行できれば一般用途では大丈夫ってことかな
あんがと
2020/08/11(火) 10:56:58.52
ライブラリ ← パッケージが詰まってる
└パッケージ ← モジュールが詰まってる
 └モジュール ← クラスや関数が詰まってる モジュール名.py
547デフォルトの名無しさん
垢版 |
2020/08/11(火) 11:03:18.24ID:x3iAuc4F
はい
2020/08/11(火) 11:20:56.57ID:Kv91d30/
>>541
withを使えばその動作は予定通りなのでは?
普通にopenしてcloseするまえに処理の競合が起きれば、また違った動作になる
2020/08/11(火) 11:28:43.21ID:1kHdySm/
競合しないように書くの良いですね
550デフォルトの名無しさん
垢版 |
2020/08/11(火) 13:08:00.16ID:IdGWSTlI
>>515
安全靴で丸坊主で歩いてるだけで逮捕だもんな
狂ってるわ
551デフォルトの名無しさん
垢版 |
2020/08/11(火) 13:12:55.63ID:IdGWSTlI
>>544-545
セマフォの役割にはmkdir()が良いってどっかで聴いた
552デフォルトの名無しさん
垢版 |
2020/08/11(火) 13:24:11.52ID:l01whKN5
perlの時代から有る手法で、ご丁寧なことに、被らないユニークな名前を生成してくれるモジュールまで存在していた
2020/08/11(火) 13:27:04.77
>>548
そう
ただ、デバッグのやり方がわからなかった
例えば
with open('hoge.txt', mode='w') as f:
_f.write('a or b')
のa.py、b.py2つ用意して
a.pyとb.pyを同時に何万回も起動実行したりとかすればいいのかなと

>>511
なるほど
2020/08/11(火) 13:28:12.84
>>553訂正 mode='w' → mode='a'
555デフォルトの名無しさん
垢版 |
2020/08/11(火) 13:42:17.84ID:IdGWSTlI
555
2020/08/11(火) 14:43:16.85ID:jY8oIKoT
>>536
Python で定数を定義する
https://maku77.github.io/python/syntax/const.html

Python には、C/C++ の const のような、定数を定義するためのキーワードは用意されていません。
2020/08/11(火) 14:57:39.72ID:nKBbqh2w
>>536
もしかして:kotae
2020/08/11(火) 15:34:48.63ID:D2zXE6xI
https://i.imgur.com/z8LRR8K.jpg
ステップ関数をグラフにしようとしてこうやったけどならないんだけど間違ってる??
保存先の13.svgをpreviewしても真っ白になる
559デフォルトの名無しさん
垢版 |
2020/08/11(火) 16:03:56.36ID:IdGWSTlI
>>558
https://dotup.org/uploda/dotup.org2225187.png
2020/08/11(火) 16:22:25.07ID:D2zXE6xI
>>559
うおおおおお!
まじで助かりました!
2020/08/11(火) 16:29:12.57ID:cFpL7en6
>>544
横だけど参考になりました
2020/08/11(火) 16:41:25.70ID:93tMQ9Bj
>>559
ステップ関数ってy=0とy=1が同じx座標になる関数じゃないの?
ズレてない?
2020/08/11(火) 16:43:36.93ID:DJf2UAfN
これくらいのステップの方が上りやすいな
564デフォルトの名無しさん
垢版 |
2020/08/11(火) 17:36:53.27ID:IdGWSTlI
>>562
x の刻みを増やせば解決する
2020/08/11(火) 18:45:02.45ID:IUnIyxWQ
今まで一つのファイルにつらつらとコードを書き連ねてたから、分割しようとしたらま〜苦労した
ライブラリとかモジュールとかただコピペして使ってただけだから、from〜importとimportの違いもよくわかってなかった
独学で必要な情報だけつまみ食いしてると基本的なことが抜け落ちてて補完が大変だ…
566デフォルトの名無しさん
垢版 |
2020/08/11(火) 21:03:59.46ID:7OoR6BUn
フレームワーク使って簡単なウェブアプリでも作ったらいい
構成からテスト、デプロイ等々、一通り網羅できるでしょ
2020/08/11(火) 23:41:09.64ID:D+9Pqaiv
https://imgur.com/gOoCERA
https://harigami.jp/cd?hsh=1e894b6f-d705-405e-9987-613886c9e6c5
Pythonとmysql-connector-pythonについてです
MySQLで画像のようなテーブルを作成し、売上が100以上200以下の社員数を営業所ごとにカウントしたいです
sql_1は期待する結果を得られていますが
sql_2やsql_3のようにプレースホルダーを使うと何も取得できません
変数でテーブル名や数値などを動的に使いたいです
プレースホルダーを使ってsql_1を実現する方法を教えて下さい
568デフォルトの名無しさん
垢版 |
2020/08/12(水) 01:27:49.12ID:t6UQqoiG
> お前は毎朝起きるたびに俺に負けたことを思い出すよ^^

あー、ホンッとに思い出すなあ(笑)
キチガイの嘘つきの低レベルFランの、
朝鮮ゴキブリBot君は、
チョン独特の「なにもできないけど俺のほうがジャップより偉い!」的な
ことはよーくわかったよ。
ホントなにもできない朝鮮ゴキブリBot君!

クソチョンw

Pythonさえろくにできないバカチョンのくせに
できるとほざくクソチョンw

日本で強姦と窃盗を繰り返す
犯罪者在日のクソチョンw
2020/08/12(水) 03:11:27.84ID:UVmFgkue
Ruby on Rails なら、

売上.where( 売上: 100..200 ).joins( 社員 ).group( 社員.営業所 ).count

Rails みたいなフレームワークを使わず、自分で文字列で、SQL 文を組み立てると、
SQL injection され放題になるけどw
2020/08/12(水) 08:22:16.74
【構成】
hoge_sample
├main.py
└packages
 ├__init__.py
 ├sample01.py
 └sample02.py

【main.py】
from packages import *
a = smpl01(1,2)
print(type(a))
print(a)
#print( dummy(1,2) )

【__init__.py】
from .sample01 import *
__all__ = [ "smpl01", '''"dummy"''' ]

【sample01.py】
from .sample02 import smpl02
def smpl01(a,b): return smpl02(a+b)
def dummy(a,b): return b-a

【sample02.py】
def smpl02(s): return str(s)
2020/08/12(水) 08:29:12.14
疑問点 >>570
(1)
【main.py】でpackages内モジュールのクラスや関数を使う時
smpl01という名前を知っていることが前提
せめて「sample01をインポートしましたよ」みたいなマーキングは必要か?
それとも【packages】みたいなパッケージのディレクトリ名から、把握しているのが前提か

(2)
packagesのサードパーティ製モジュールのimportは相対パスで指定している
デバッグのために【sample01.py】を直接起動させると
smple02が使えない
2020/08/12(水) 08:39:48.51
訂正 >>570
【__init__.py】
from .sample01 import *
__all__ = [ "smpl01" ] #["smpl01","dummy"]
2020/08/12(水) 08:47:45.76ID:+7u2t/Rq
まずtableがデータベースのテーブルではなくカラムになっていて紛らわしい
通報されるレベル

cursor.execute()の前にcursor(prepared=True)を実行しているか分からないが大丈夫か?

> cursor.execute(sql_2, (table, table, x_min, table, x_max))

は問題がないように見える

> cursor.execute(sql_2, (table, x_min, x_max))

は%sと引数の数があっていない

> cursor.execute(sql_3, {'table': table, 'x_min': x_min, 'x_max': x_max})

はこの文法が通用するのは比較的新しいPyMySQL(0.7.9以降?)だがバージョンは大丈夫か?

https://github.com/PyMySQL/PyMySQL/blob/73c22c78d14466a5ed8029ef67ca11198234913e/pymysql/cursors.py#L158
2020/08/12(水) 09:09:26.38ID:+7u2t/Rq
>>571
(1)は言いたいこと良くが分からない
アスタリスクが全ての元凶のように見えるが・・・
この構成の作り方だと
packages.sample01 … module
packages.sample02 … module
packages.smpl01 … function
がmain.pyからは見える

(2)は相対インポートがパッケージ内でのみ機能する記法だから
直接実行すると相対インポートがエラーになる
回避方法は
python -m packages.sample01
として実行する方法だが、上記の構成で__init__.pyが定義されているため警告はでる
2020/08/12(水) 10:01:11.25
>>574
>python -m packages.sample01
d できた
なぜか警告も出なかった

(1)は最初
from packages.sample01 import smpl01
にしてたけど他にも使いたいモジュールが出てきたら
fromなんちゃらの行が【main.py】に延々追加されていくので
それなら__init__.pyの方に纏めておいた方が見やすいのか?と思った
2020/08/12(水) 10:13:01.58ID:r3C450gU
>>573
こんな書き方できるのか。知らんかった
mysqlclientで順番に値を放り込む方法しか使ったことないや
2020/08/12(水) 11:54:40.35ID:dVYQOL+d
https://harigami.jp/cd?hsh=9af27284-08c6-4b67-8f9a-0bfcffb213b2
すみません、まだやってます・・・そろそろ諦めようかな・・・
2020/08/12(水) 13:06:36.68ID:r3C450gU
>>577
カラム名を%sにするとだめみたいよ
置換フィールドで放り込んでやるとうまくいった

sql_4 = "SELECT 社員.営業所, COUNT(売上.売上) " \
      "FROM 社員 LEFT JOIN 売上 " \
      "ON 社員.社員ID = 売上.社員ID" \
      "WHERE {table} BETWEEN %s AND %s " \
      "GROUP BY 社員.営業所".format(table='売上.売上')
2020/08/12(水) 13:38:11.01ID:+7u2t/Rq
>>575
python -m packages.sample01
で警告が出るのはpythonのバージョンのせいかも知れない(python3.7では警告が出た)
この方法では
packages/__init__.py
がまず読み込まれ、その後
packages/sample01.py
が実行される
__init__.pyでsample01.pyを読み込んでいるので、sample01.pyは2回読み込まれていることに注意

__init__.pyにまとめることは普通に良くやるしpackages/__init__.pyの中でアスタリスクを使うことも良くやる
ただしmain.pyでアスタリスクを使うのは行儀が悪いように思う
fromナンチャラの行が増えるのが嫌いなら、メモリは食うけど
import packages
とした方が心の健康によさげ
2020/08/12(水) 13:54:59.57ID:+7u2t/Rq
>>577,578
>カラム名を%sにするとだめみたいよ
これが全て
2020/08/12(水) 14:15:16.02
>>579
>2回読み込まれ
あーやっぱりそうだったのか なぜか2倍printされるので。。

>ただしmain.pyでアスタリスクを使うのは行儀が悪いよう
なるほど
2020/08/12(水) 14:19:38.23ID:dVYQOL+d
>>578
できました!やったーありがとうございます
583デフォルトの名無しさん
垢版 |
2020/08/12(水) 14:21:32.92ID:q6njxWnQ
実用的でないPythonプログラミングを買いました。
VisualStudio2017とかでできますか?
皆さんオススメの環境を教えてください。
Pythonのバージョンは3.5らしいです。
(まだちゃんと読んでないけど)
2020/08/12(水) 15:03:29.71ID:+7u2t/Rq
Windowsなら
Python: Anaconda
エディタ: Visual Studio Code (VisualStudioではない)
2020/08/12(水) 15:21:07.28ID:JA3gbSGM
>>583
AnacondaPrompt
エディタはNotePad++
586デフォルトの名無しさん
垢版 |
2020/08/12(水) 15:24:26.55ID:q6njxWnQ
>>584
>>585
有り難みが強い。
参考にさせていただきます。
587デフォルトの名無しさん
垢版 |
2020/08/13(木) 10:56:33.23ID:0rwjVY3B
イテレータとリストの違いですが、イテレータは処理途中の状態を記録できるという点が違うのでしょうか?
588デフォルトの名無しさん
垢版 |
2020/08/13(木) 11:27:43.34ID:WWRPvGcb
違う
君が言う後者の機能は generator

リスト は全部メモリに確保されたもの
イテレータ はメモリを占有せずに順番に値を取得
generator は処理途中の状態を記録できる

イテレータの実装に generator が使われているかも知れないが別の概念
2020/08/13(木) 11:27:51.35ID:RJ8S/0mc
作り置きと、注文の都度作るかの違い
作り置きは、置き場のスペースが必要
590デフォルトの名無しさん
垢版 |
2020/08/13(木) 11:43:13.98ID:CM5c4LB7
リストとイテレータの違いがよくわからないのですが、かんたんナ... - Yahoo!知恵袋
https://detail.chiebukuro.yahoo.co.jp/qa/question_detail/q12229812432

これでは分らなかったのか
591デフォルトの名無しさん
垢版 |
2020/08/13(木) 12:28:04.42ID:0rwjVY3B
なるほど、なんとなくわかったです
2020/08/13(木) 12:48:37.94ID:BKihMO2y
foo = [1,2,3]
foo_iter = iter(foo)
next(foo_iter) #=> 1
next(foo_iter) #=> 2
next(foo_iter) #=> 3
next(foo_iter) #=> StopIteration

イテレータはnext()が呼ばれたら次の要素を1つ返すオブジェクト
内部でどこまで返したか覚えておく必要があるので状態を記録してるかというと記録してる

for x in foo: って書けば
iter(foo)して、next()を呼んで、得られた値をxに代入して、loop内の処理へ渡してる

ジェネレータは一般的には呼ばれたら1つ1つ値を生成して返す関数でイテレータの一種
ジェネレータではないイテレータは1つ1つ値を生成するんじゃなく
すでに用意されたリストなどから順に値を1つずつ返すもの
なので作り置きから注文の都度1つずつ返すのもイテレータ
593デフォルトの名無しさん
垢版 |
2020/08/13(木) 13:00:42.76ID:0rwjVY3B
何故pathで取得したパスは、iterdirなどを使ってジェネレータにする必要があるんでしょうか?
ササッとリストでも取得してくれればいいんじゃないですか?

フォルダのファイル一覧を取得する場合、
パス→ジェネレータ生成→リスト化という手順を踏まないといけないみたいです
パス→リスト
でいいような、、
594デフォルトの名無しさん
垢版 |
2020/08/13(木) 13:05:38.39ID:KaPqduB6
python2 へようこそ
2020/08/13(木) 13:10:29.18ID:xFixv4R5
一言で言うと「yieldがあるのがgenerator」
2020/08/13(木) 13:13:43.47ID:xFixv4R5
>>593
項目が超巨大になったときにリストの実態返されたら悲しいことになる
ジェネレータなら、あれ?なんかでかいぞ、止めよう、ができる
597デフォルトの名無しさん
垢版 |
2020/08/13(木) 13:39:30.96ID:0rwjVY3B
>>596
な、なるほど
そこまで巨大なファイルを扱ったことはなかったので、必要性が分からんでした
598デフォルトの名無しさん
垢版 |
2020/08/13(木) 13:56:32.50ID:CM5c4LB7
やっぱり強制的に教え込むべきだ
業界が先祖返りしてる

計算機プログラムの構造と解釈 第二版
https://sicp.iijlab.net/fulltext/x350.html
2020/08/13(木) 14:04:29.87ID:jm0McRWL
>>592
> ジェネレータは一般的には呼ばれたら1つ1つ値を生成して返す関数でイテレータの一種
逆でしょ
「イテレータは、コンテナに含まれる値ひとつひとつに対して走るジェネレータの一種である。」
ハードウェア乱数生成装置から読み取った値を返すジェネレータとか内部で値を保持しないジェネレータとかもある
>>588とかも勘違いしてる
600デフォルトの名無しさん
垢版 |
2020/08/13(木) 14:28:08.21ID:WYCQl6Jw
>>598
先祖還りって言うか
もう3周目とか4周目だろう
2020/08/13(木) 14:31:15.88ID:BKihMO2y
>>599
逆じゃないよ

>「イテレータは、コンテナに含まれる値ひとつひとつに対して走るジェネレータの一種である。」
こういう味方があっても別いいとは思うけど一般的ではない

>ハードウェア乱数生成装置から読み取った値を返すジェネレータとか内部で値を保持しないジェネレータとかもある
yield 乱数生成()で値を返すジェネレータがあったとして
何回yieldしたかとかloop条件を満たしてるかどうかとか
なんらかの状態を内部に保持することになるよね?
602デフォルトの名無しさん
垢版 |
2020/08/13(木) 14:57:12.58ID:0rwjVY3B
ループの返り値を内包表記を使用して変数に挿れるのと、普通にループで記載する場合では何が違うんでしょうか?後者だとグローバル変数が必要になると思いますけど。
2020/08/13(木) 15:04:40.77ID:cLv1fX6M
>>602

https://qiita.com/intermezzo-fr/items/43f90e07e4cebe63aeb6
2020/08/13(木) 15:11:06.77ID:RDWqdqfD
>>601
> こういう味方があっても別いいとは思うけど一般的ではない
いや、なんの根拠もないお前の定義を一般的と主張されても困るよw
イテレータは必ずジェネレータだけどイテレータでないジェネレータはあるだろ(その例が乱数発生器)

> yield 乱数生成()で値を返すジェネレータがあったとして
> 何回yieldしたかとかloop条件を満たしてるかどうかとか
> なんらかの状態を内部に保持することになるよね?
そりゃ、そういうジェネレータならそうだろう…
内部情報を保持しない例に保持する奴持ってきて何を言いたいんだ?
2020/08/13(木) 15:27:20.97ID:TgMttUh/
>イテレータは必ずジェネレータだけど

どこからこんな解釈が?
pythonのイテレータはイテレータプロトコルをサポートするオブジェクトのことだし、
ジェネレータは呼ばれたらイテレータを返す関数のことだろ。
2020/08/13(木) 15:41:35.50ID:BKihMO2y
>>604
日本語のWikipediaの間違った記載を鵜呑みにしてるっぽいね
https://ja.wikipedia.org/wiki/ジェネレータ_(プログラミング)

英語版も見るといいよ
https://en.wikipedia.org/wiki/Generator_(computer_programming)

疑似乱数生成器(Psuedo Random Number Generator)の名前にジェネレータが含まれてるからといって
それらがプログラミング言語でいうところのジェネレータを使って実装されてるわけじゃないから
2020/08/13(木) 15:43:11.84ID:BKihMO2y
>>606
>それらがプログラミング言語でいうところのジェネレータを使って実装されてるわけじゃないから

それらが”すべて”プログラミング言語でいうところのジェネレータを使って実装されてるわけじゃないね
ジェネレータのものもあればそうでないものもあるということ
608デフォルトの名無しさん
垢版 |
2020/08/13(木) 15:45:42.36ID:hDTlT7Ky
酷いのが居るな
知らないのなら黙ってれば良いのに
2020/08/13(木) 16:08:22.81ID:3TUGpUf8
>>605
>イテレータは必ずジェネレータだけど

逆ぅ!

>>> import collections, types
>>> issubclass(types.GeneratorType, collections.Iterator)
True
610609
垢版 |
2020/08/13(木) 16:21:41.93ID:3TUGpUf8
訂正
>>609>>604へのレスね。
2020/08/13(木) 16:34:47.69
tkinterでmainloopする前に無限ループ処理をしたいのですが
無限ループ処理Aをするとmainloop()できない
mainloop()を先に、無限ループ処理Aを後にすると、無限ループ処理Aできない
という板挟みになりました
どうしたら良いのでしょうか
import tkinter as tk
import time
while True:
_print("処理")
_time.sleep(1)
root = tk.TK()
root.mainloop()
2020/08/13(木) 16:52:12.14ID:wdeLOLBT
クラスの使い道がわからん
数値や文字を関数に放り込んで値を出して表示する
これだけでやりたいことが全部できてやることがなくなった
2020/08/13(木) 17:18:52.97ID:ut3SsjSC
>>611
root = tk.Tk()

def mokomoko():
処理
root.after(1000, mokomoko)

root.after(1000, mokomoko)
root.mainloop()
2020/08/13(木) 17:19:09.07ID:P/jo0Y4p
>>612
そのとおり
クラスなんかなくても何でも書ける

ただしクラスという抽象化手段は、単に書けるという以上のものを目指すときに使う
例えば再利用とか
615デフォルトの名無しさん
垢版 |
2020/08/13(木) 17:22:35.60ID:CM5c4LB7
>>611
まずはかんたんなアナログ時計から作った方がいい
2020/08/13(木) 17:32:17.63
>>613
できました ありがとうございます
ついでにボタンを追加してみたのですが
処理中はなぜかプッシュ感がありませんでした
ボタンクリックしても押し込まれるアニメーションが出てこない(処理が終わった瞬間、処理前に押したときのボタン処理がドバーッと実行される)のですがそういうものなんでしょうか
2020/08/13(木) 17:34:45.02
>>615
とりあえずストップウォッチのコードを眺めてみることにします
2020/08/13(木) 17:53:26.38ID:DN44Q+/a
何かしらPythonでなければならない理由があるならともかくGUIならC#で作った方が楽じゃないか?
619デフォルトの名無しさん
垢版 |
2020/08/13(木) 17:56:22.43ID:1iT07aDZ
>>618
ココはPython の布教>>1
2020/08/13(木) 18:05:56.78ID:BJex6KXt
>>616
細かい所を拘るなら
PySimpleGUIとか別ライブラリを使うのも手
(tkinter自体は大昔からあるやつだから、モダンな物を作ろうとするとちょっと大変)
2020/08/13(木) 18:11:59.85
https://ideone.com/h4QkaK
とりあえずストップウォッチを参考に書いてみましたが
やはりボタンのプッシュ感がありません
なぜでしょうか
明らかにroot.afterの行が原因で止まっているんだろうな、という感じです
2020/08/13(木) 18:12:22.88
>>620
なるほど ぐぐってみます
623デフォルトの名無しさん
垢版 |
2020/08/13(木) 18:14:57.99ID:0rwjVY3B
複数フォルダの先頭ファイルのみ取り出すにはどういうロジックにしたらいいんでしょうか?
フォルダのインデックス0を取り出したあと、各々のフォルダの中でファイルのインデックス0を取り出すという手順になるでしょうか
624デフォルトの名無しさん
垢版 |
2020/08/13(木) 18:15:56.91ID:0rwjVY3B
あ、違いますね。
フォルダのインデックス0という点は間違いです。フォルダ構造です。

フォルダ1
┗ファイル1
┗ファイル2
フォルダ2
┗ファイル3
┗ファイル4
2020/08/13(木) 18:32:21.11
自己解決したかどうかわかりませんが(意図した処理と同等かよくわからない)一応ボタンが常にプッシュしてくれるようになりました >>621
https://ideone.com/GOuxDw
2020/08/13(木) 19:42:17.54ID:2TasqE+0
>>623-624
その子供ファイルたちの「一番目」って何で決めるの?
サイズ?日付?名前???
627デフォルトの名無しさん
垢版 |
2020/08/13(木) 20:42:25.92ID:0rwjVY3B
sortedを使用するので、名前です(´・ω・`)、、、
2020/08/13(木) 20:46:52.26ID:4HMLW5OS
フォルダの一覧を作成。
各フォルダについて最初のファイルを取得して、ファイルパスをリストに追加。
2020/08/13(木) 20:58:21.33ID:vQKb1geh
>>587
一般論であれば、まずPythonにおける「リスト」とは
他言語における「配列」を指す

次に、配列とは単なるデータ構造を指し、
その配列の各要素をあれこれ処理するアルゴリズムは「手続き」として定義される
データ構造と手続きが完全に分離されている、これがFORTRAN/COBOLに始まり
C/Pascal/Modulaへと続く1980年代前半までの古典的な「手続き型言語」の流れ

こうした手続き型の流れは、大規模開発における保守性/再利用性の低さから批判を受け、
対処策として注目された概念の一つが「抽象データ」であり、
これはデータ構造の内部詳細を隠蔽し外部に公開された手続きで処理対象をモデル化する
たとえばスタックという抽象データは、内部のデータ構造が配列であっても
リンクドリストであっても構わず、外部に公開されたEmpty/Push/Pop/IsEmptyという
手続きの集合(インターフェイス)だけで定義される

この抽象データという概念を発展させて、反復(ループ)処理すらも抽象化させるという提案が
イテレータ(iterator, 反復子)であり、それが最初に実装されたのがCluと呼ばれる実験的言語になる
まとめると、リスト(=配列)とはデータ構造の一種であり、イテレータとはリストを含む
複合データ構造に関する反復処理に限定して抽象データとしてモデル化した概念である
630デフォルトの名無しさん
垢版 |
2020/08/13(木) 21:02:29.42ID:0rwjVY3B
>>628
ロジックは最初に日本語化したほうがいいですか?
2020/08/13(木) 21:07:21.03ID:4HMLW5OS
>>630
英語の方が分かりやすいなら英語で。伝統的な日本人なら日本語で。
2020/08/13(木) 21:18:06.70
PySimpleGUI調べてみました
圧倒的にコードが見やすくなりました

特徴は、レイアウトを最初にまとめてコーディングして
最後にWhile True:でイベントを監視するところでしょうか。

event, value = window.read()の直前後にprintを挟んでテストしてみましたが
一番最初にそのprintが出力され、次にイベントの処理が出力されました
つまりwindow.read()のところで待機?してるのだと思いますが
その仕組みが今一わからず悶々としています
2020/08/13(木) 21:25:29.32ID:vQKb1geh
>>631
リストに対応する英単語は list であり、
同様に、配列に対応する英単語は array(アレイ) または vector(ベクタ) である

何を言いたいのかな?
英語?日本語?言語は関係ないよ
2020/08/13(木) 22:05:38.43ID:SL8XbHj+
はじめてpysimpleguiを知ったんだけど、tkinterやqtのラッパーだなんて説明を見つけたけど本当?
公式の英語を読むと、ラッパーなんて記述は見つからないのだが。
2020/08/13(木) 23:41:28.50ID:ut3SsjSC
5秒で見つけたぞ
https://pysimplegui.readthedocs.io/en/latest/#whats-the-big-deal-what-is-it
2020/08/13(木) 23:45:08.41ID:SL8XbHj+
あ、ホントだ。てことは、exe配布時に必要なバッケージはどうなるんだ?
全部?
2020/08/14(金) 00:07:27.84ID:SCMnTycc
例えば、メモ帳のパスなら、コマンドプロンプトで確認できる。
上に表示される方が、優先される

where notepad
C:\Windows\System32\notepad.exe
C:\Windows\notepad.exe

同様に、where php とやってみれば?

環境変数パスを知らないような人は、システム環境構築運用なんて、とてもできない
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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