Pythonのお勉強 Part68
■ このスレッドは過去ログ倉庫に格納されています
!extend:default:vvvvv:1000:1024 !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(超初心者用) その57 http://mevius.5ch.net/test/read.cgi/tech/1653225908/ 〇前スレ〇 Pythonのお勉強 Part67 https://mevius.5ch.net/test/read.cgi/tech/1653540315/ 次スレの建立は>>985 が挑戦する。(980通過して24h後も落ちなくなった) ### END of TEMPLATE ### VIPQ2_EXTDAT: default:vvvvv:1000:512:: EXT was configured メモリマップとかで、 A: 0x0000 - 0x0fff B: 0x1000 - 0x1fff みたいに末尾をfffにせずに、末尾は1足して表記する、という約束にした方が使いやすい そうすると最後は F: 0xf000 - 0x10000 と最後だけ2バイトでは表記しきれなくなるね すみません、プログラミング初心者です、python構築について質問があります python3.10.7をインストールしたのですがコンドプロンプトで確認したらpython 3.9.12になっています もしかしたら以前DLしてたのかと思って探しても見つからないのですが こういうものなのでしょうか? すみません、調べてみたらanacondaの方にpythonが入ってたみたいです >>101 そんなに有名な事でしたか… 調べても出てこなかったので 君は悪くない、anacondaも悪くない anacondaを進める入門的な書籍やサイトが悪い pipでバイナリを配布できなかった時代ならまだしも、今そんな時代じゃないしな~ 何かのツールをインストールするとpythonも一緒にインストールされるのはよくある python2だったりもする 大抵は、自分用のバイナリを自分で使うだけなので迷惑はかけないけど、 行儀の悪い奴もいる 未だにpython事始めで検索すると 無責任な入門サイトの「anaconda入れとけ☆」 ばっかり いやべつにいいんだけどさあanacondaでも。オールインワンで便利なのも分かるけど anacondaでもpipでも両方使えばいいジャマイカ condaのコマンドで新しい環境作れるようにしたらスタンドアロンのpythonが外れた記憶ある 俺も初心者の頃はアナコンダ入れてた。 けど後から無駄も多く必要ないことがわかったのでアンインストールした。 pythonとVSCodeあれば事足りる。 ファイル名に使えない文字を全角に変換するコードってこんなに長くなるものなんですか? https://qiita.com/kusunamisuna/items/a32679874afedc032158 name_ng = ["/","\",":","*","?","<",">","|"] こんな感じでリストに入れてfor文の中で replace で置換すれば良いんじゃないかと思ったけど、リストにする段階でエラーになります 上記のURLの記述が最適解? 簡略化された書き方があったら教えてほしいです。 a=True b=True aかつbがTrue、それ以外の全て の条件って if not (a and b): でよかったっけ・・? >>111 translate使えばforすらいらない >>111 その記事が最適かどうかは別問題として、まず0x5cをちゃんとエスケープして、あなたの考えを動くコードとして完成させよう その上で、記事のコードと分かりやすさや速度を気の済むまで比較してみればよい >>113 調べて試してみます >>114 そもそも ”\” は文字列としても単体では使うことができない感じですかね? 知らなかったです。教えてくれてありがとうございます >>112 if all([a, b]): else allとanyは積極的に使おう フラグを別に持つとか途中で抜けてループ変数を見るとか、 何でレガシーな言語はそれで満足してたのか判らん 今日からPython始めたんだけど、エラーが出て動かなくて悩んでたらインデントが原因だったw 調べたらインデント自体プログラム構造的に意味を持ってたんだな。。。 少しコードが長くなってきたので、関数を定義してみようと思ったのですが 関数を使うくらいなら、最初からclassとmethodでやった方が後々便利ですかね? それから現段階ではまだinstance変数を使うかどうかは不明ですが classの最初に__init__は決まり文句として書いておいて良いのでしょうか? 仮に全く使わなかった場合にバグの元になったりするのでしょうか? そのレベルならまず関数に慣れよう classはそのあと classを使うほうが常に優れていると思ってるなら認識を改めたほうがいいよ。 classと関数両方使えるがpythonのメリット。 標準ライブラリだって両方共存してるのにどちらかを捨てるなんてもったいない 自己満だからといっていつも意識的にそれらを考えていかなければより良い設計はできないのかもしれない クラスはメンバ変数にselfが強制だからコードが冗長になって嫌だわ >>125 インデントも深くなるし、状態持つ必要が無ければモジュール化で十分よな 大仰なクラスを作ろうとするから インスタンス変数が2つだけ、みたいなのでも十分役立つ >>127 それくらいならNamedTupleでも良いかな クラス名をclass Hoge ファイル名をhoge.py インポートでimport hoge インスタンス名何にしようかいつも悩む ??? = hoge.Hoge() >>81 そもそも[0,1]のときにx[0]を2つ取り出したいのかどうかがよくわからないな あと、最大(?)は[0,10]じゃないか? [0,9]のときと[0,10]のときでどう処理を変えたいのかよくわからない 半開区間に含まれる最小最大を取り出したいなら、 for i in [idxs[0], idxs[1] - 1]でいいと思うのだけどこれは嫌? 木構造とかグラフ構造を自作したいなら(間々ある)、 クラスにした方が便利なときある気がするけどな。 get_tree_children(node)とかしだすなら、node.children()の方が名前空間がすっきりしていいし。 実装の詳細を見せたくないかどうかというよりは、関心の分離をしたいかどうかによるような気がするな。 確かにクラス作るまでもないようなことは多いけど。 python 3.9.10 a = (1, 2, 3) b = a c = (1, 2, 3) print(a==b) print(a is b) print(a==c) print(a is c) #True? なぜ a is c が true になるのでしょうか? >>139 それREPLでやってるからinterningが効いてないじゃないかな >>135 Tupleはimmutableだからaとcが同じオブジェクトを指しても問題なくて Pythonが最適化をした場合はa is cがTrueになるケースがある 「interning」でググってみて 例えばTupleを関数で返すようにすればinterningされずにFalseになると思う def foo(x): return (x, x+1, x+2) a = foo(1) c = foo(1) >>140 ありがとうございます、オプティマイゼーションの余地がある、ということですね、納得しました a is cが真になるかはかなりケースバイケースな気がするし、 中身を比較したいんだったら使うべきじゃないね 本当に同じtupleインスタンスかどうかを確認したいときだけにすべき tupleだけの話ではなくてどの型でも同じだけどね 例えば文字列とか n=12345.67 小数点以下が何桁あるのか調べたいのですが len(str(n).split(".")[1]) if isinstance(n, float) else 0 こんなんでいいですかね・・? >>144 誤差で予想外の挙動しそうだからDecimal使う方がいい >>144 それだと n=1.0 -> 1 n=0.00001 -> IndexError になる len(format(n,".17f").split(".")[1].rstrip("0")) 後ろのif isinstance(n, float) else 0も不要 n=1.0 -> 0 n=0.00001 -> 5 >>145-147 たしかに 0.30000000000000004に対して17得られたのは正解だと思いますが 0.00001で1e-05になっててエラーでました Decimalかformat使ってみようと思います ありがとうございました やりたかったことは 受けとった1234.56や0.12345などの固定小数点数に 0.1とかを掛けたり足したりして計算、変形したのを 受け取った固定小数点数の整数部と小数部の数を維持したまま 固定小数点か文字列で処理したかったのですが 改めてやってみるとなんか勝手に桁数が変わってしまいますね・・ 1234.56で受け取った場合、1.05を掛けたとき→1296.288ではなく1296.29 0.12345で受け取った場合、1.05を掛けたとき→0.1296225ではなく0.12962 1234で受け取った場合、1.05を掛けたとき→1295.7でもいいし1296でもいいし1296.0でもいい みたいにしたかったのですが難しい・・ from decimal import Decimal str(Decimal(0.123456)) str(Decimal(0.123456)*Decimal(1.05)) #'0.1296288000000000015945911258' あれ、そもそも0.123456の小数部の桁数はどうやって知るんだっけ?? てところで詰まってます・・ 冗長な気がしますがこんな感じにしてみました 何かバグが発生しそうな気がします from decimal import Decimal ary=[1234.5,165,0.34,0.0001,0.000001,3.00001,0.1*3,123456] def f(n): s=format(n) return int(s.split("-")[1]) if "-" in s else len(s.split(".")[1].rstrip("0")) if "." in s else 0 r=1.05 for n in ary: d=f(n) c=Decimal(n)*Decimal(r) rs=c.quantize(Decimal("0."+("0"*d))) print(n,c,d) print("-->",rs,"\n") >>152 format使うの提案したけど使わないほうがよさそう、誤差がでる f(n): 負数で落ちる s=str(n).lstrip("-") c=Decimal(n*r) のところで n*r で誤差がでる c=Decimal(str(n)) * Decimal(str(r)) 負数対応四捨五入 -0.015 を四捨五入して -0.02 rs=((c > 0) - (c < 0)) * abs(c).quantize(Decimal("0."+("0"*d)), rounding=ROUND_HALF_UP) -0.015 を四捨五入して -0.01のようにしたい場合 rs=c.quantize(Decimal("0."+("0"*d)), rounding=ROUND_HALF_UP) 四捨五入したいのかよくわからんかった、roundingは好みのオプションでどうぞ >>154 ありがとうございます やはり至るところで誤差が発生するのですね 四捨五入は今回の用途ではどちらでも良い感じです せっかくなのでまとめてみました https://ideone.com/JmTu06 ありがとうございました 先にIEEE754読んでみては? 誤差に関しての勘所がわかるようになる Pythonに限らず浮動小数点数を使う場合は常に誤差の問題がつきまとう。 0.1というのがすでに二進数ではきっちり表現できない数字なので、有効数字を何桁にするのかというのは実装の段階で決めなくちゃならない。 https://docs.python.org/ja/3/tutorial/floatingpoint.html 正確に表現できるのは、0.5,0.25,0.125...と1を2で割っていった数とその整数倍のみ 0.1は1/(2×5)となり1/5が2進数では循環小数となり浮動小数点数では正確に表せない。 ということを念頭に置いてまず何がやりたいか考えた方がいいよ。 decimalモジュールは便利そうだね。 >>154 どちらの書き方でも -0.015 を四捨五入したら-0.02だった、すまん -0.01にしたい場合は自力でなんとかして 昔から不思議なんだけど 何で分数で処理しないのかな? 最後に割り算を一回だけすれば 誤差がでないじゃないの Pythonは整数側の桁数制限が無いのを利用して高精度にできそう >>160 似たような大きさの数字ならその発想もいいけどね 現実はコスパの悪い任意精度の演算が必要になることが多いのでは >>160 昔GCD付きの分数クラス作ったけど 結局はdoubleになったことがある >>160 四則演算だけならいいけど√とかsin( )とかはどうする? >>161 掛け算、足し算で誤差がでるケースとは? python chapelについて質問です。 情報があまりないので、チャペルについてお勧めのサイトがあれば教えてほしいです。 クヌースのTAOCP読むといいよ コンピュータでの数値計算の全てが書かれてる >>170 sinsin, cos のまま計算するって話だろ 数学不得意か? >>174 話は>>160 から始まってて途中は代数的な操作で最後に一回だけ演算することで誤差を抑えられるって話な 組み込み系で、積算の量を保持していて 1秒毎に測定して何年というスパンで計算を続けると、 もう32bitでは精度が足りなくなる 最後に浮動小数点数にして誤差を減らす方法は、代数的な計算ができる必要がある。 Mathematicaとか、SymPyだな。 ただ代数的な計算は上手いこと式を整理してやらないと簡単にならないことも多い。積分は公式を知らないと出来ない、というのと同じ。 有理数の四則演算だったら単なる有理数演算を逐次的に実行していけば問題ないだろうが。 >>177 んなことないだろ。加法定理やら積和、和積の公式とか習わなかったのか。あの辺使うと極端な場合の誤差減らせるよ。 xが0に非常に近い場合のsin2x/sinxとかね。 お金の計算とかは 有理数しか出てこないんだから 分数で十分のような気がするんだが 丸めたくない意図だと思うが加減算だけで速攻破綻する 単にbit数が足りなくなるという話なので、 必要に応じてbit数を増やしていけばいい 無限に増えることは絶対ない 質問です。 djangoの資格を作りたいとおもってます。 需要はありますか? https://translate.google.com/ Google翻訳のページで、テキスト入力ボックスから「Tabキー」を1回押すと必ず「音声を聞く」のアイコンに移動するようにしたいのですが、Pythonで可能ですか? 通常は3回で行けるのですが、”原文の言語”や”もしかして”が表示されるとTabキーを押す回数が変わって面倒です。しかもリストが表示されててそのパターンなのか見えない。 Pythonで何とかしようとしてるのがそもそも間違っている気がして、簡単なHPをJavaとか?で作ったり、アドオンを組んだりとか別の手段が必要ですかね? >>188 現在のフォーカスを取得することでTab回数制御できそうだけど そもそも音声を聞く、のidありゃそこに飛ばせるやろ >>190 seleniumを使ってプログラムを実行した時だけなら出来たのですが、普段使いで常にその状態にさせる方法が分からなかったです。 独自の簡単なChrome拡張機能を作る方向が一番良さそうな感じです。そっちで少しやってみます。お騒がせしました。 >>191 拡張起こさなくてもTampermonkey拡張でスクリプト書くだけ USWCとか使ってESCキーを押したら画像認識で再生ボタンクリックとかにすると簡単そう ESCだと位置的に押しやすいし予測候補も消える pyautoguiみたいなの使えばPythonでもUWSCと同じ事出来たはず windows限定の話だけど 拡張する方向でやってもすぐに使えなくなったりするので、 キーやマウスの操作を発生させる方向でやるのが結局ベストだったりする ■ このスレッドは過去ログ倉庫に格納されています
read.cgi ver 07.5.5 2024/06/08 Walang Kapalit ★ | Donguri System Team 5ちゃんねる