Pythonのお勉強 Part73

レス数が950を超えています。1000を超えると書き込みができなくなります。
1デフォルトの名無しさん (ワッチョイ f610-G7il)
垢版 |
2024/06/06(木) 08:48:10.07ID:DsazphEm0
!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のお勉強 Part72
https://mevius.5ch.net/test/read.cgi/tech/1703659345/
VIPQ2_EXTDAT: default:vvvvv:1000:512:: EXT was configured
887デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 18:36:54.21ID:ZvPXoPz+0
>>886
とりあえず2時間のやつで雰囲気掴んだ後に、どれを見ればいいのかわかんないのよね…

あと書籍っていうある程度まとめて基礎の基礎何詰まってるモノが欲しいんだ
いつでも読めるように
888デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 18:40:19.95ID:ZvPXoPz+0
プログラムはできるだけシンプルで、うまく動かなかったり不具合出た時に、他の人でも修正位置がわかりやすく、後から機能を追加しやすいフレキシブルなモノが良いってのはなんとなくわかるのよ…

まず、それを書く知識が全くと言っていいほどないんだよね🙃
889デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 18:42:15.28ID:ZvPXoPz+0
なので、どの動画が自分の欲しい情報解説してあるモノなのかの判断もつかない状態です
890デフォルトの名無しさん (ワッチョイ 8aa5-f0zi)
垢版 |
2024/09/08(日) 18:45:56.99ID:nFVqfsuv0
>>889
さっさと実務をやった方がいいです。
ダサいコードが仕様変更に耐えられるコードです。
891デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 18:47:04.49ID:ZvPXoPz+0
>>890
とりあえず組みたいプログラムに取り掛かれって事?
2024/09/08(日) 18:47:11.49ID:zGDX69KT0
https://www.youtube.com/watch?v=tCMl1AWfhQQ
2時間てこれか
いいのあるじゃん

これでオリエンテーションは終わりなので、あとは好きなことをやればいい
893デフォルトの名無しさん (ワッチョイ 8aa5-f0zi)
垢版 |
2024/09/08(日) 18:47:19.73ID:nFVqfsuv0
書籍を書いているのはプロじゃないので、モジュールの切り出しすらも説明していない。
894デフォルトの名無しさん (ワッチョイ 8aa5-f0zi)
垢版 |
2024/09/08(日) 18:48:20.74ID:nFVqfsuv0
>>891
自分自身が使うものを作る。あとから変えようとしたときにこう作るんじゃなかったと気づく。
895デフォルトの名無しさん (ワッチョイ 8aa5-f0zi)
垢版 |
2024/09/08(日) 18:50:05.63ID:nFVqfsuv0
実務の意味がわからないというのは学生なのかな?
896デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 18:50:58.16ID:ZvPXoPz+0
>>895
プログラミングの用語とかも知らんのです
2024/09/08(日) 18:53:49.27ID:SEDRCJr/0
全くのプログラミング初心者なら
「プログラムはなぜ動くのか」
辺りかな
898デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 18:57:59.46ID:ZvPXoPz+0
>>892
これは↑でオススメしてもらった
これを繰り返し見つつ、同時進行していく感じかー

ありがとう
実践しながらやってみるわ

最初の方から結構「???」ってなる部分も多いんだんだけどもw
899デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 19:02:39.95ID:ZvPXoPz+0
>>893
なんか良い、こんなオレでも比較的理解できる良い書籍あります?
2024/09/08(日) 19:24:36.64ID:6sSIgrGd0
>>889
>どの動画が自分の欲しい情報解説してあるモノなのかの判断もつかない状態

>>856読んで貰えてないんだね。
Paizaってサイトではそういう人でも分かるように順序立てて基本的な文法を動画で解説してくれてる。
他の言語の場合は冒頭のみであとは有料だけど、Pathon3だけはある程度の部分まで無料公開してくれてる。
ここで無料公開分を全部終了できれば初心者向けの動画とか解説サイトとかもそれなりに理解できるようになると思う。
お金掛からないしとりあえずやってみたら?
901デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 19:26:21.18ID:ZvPXoPz+0
>>900
呼んだっす!
コピペして、学ぶ順序のリストにさせてもらった
902デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 19:30:52.42ID:ZvPXoPz+0
助言で具体的なものは全て書き出したり、登録、購入検討してる

ただ昨日の今日で、サプーさんの書籍も今目を通したとこなので、リストの優先順位を判断できてなくて
2024/09/08(日) 19:31:24.09ID:SLqL4HNM0
>>881,882,883
ありがとうございます!
時間あるときにチャレンジしてみます!
904デフォルトの名無しさん (ワッチョイ 911d-sF61)
垢版 |
2024/09/08(日) 19:38:08.04ID:ZvPXoPz+0
>>900
サプーさんの2時間の動画見ても、結構「???」なとこ多くて、書籍はまだ理解できるレベルじゃないものだったので、Paizaってサイトに挑戦してみます

詳しくレスしてくれてありがとう
2024/09/08(日) 22:39:01.10ID:zGDX69KT0
何か裏で処理させてて、完了したらポップアップで知らせたい
それだけなら方法はいくらでもあるけど、
よし判ったとEnter一発で閉じたい
でもポップアップにフォーカスが無いので、いろいろ面倒くさい
ポップアップの位置もど真ん中に出ると邪魔なので端に寄せたい
でも tkinter でどう頑張ってもそんなことできない
2024/09/08(日) 23:07:02.96ID:FaHdpY160
ずっと画面見てる前提なら数秒したら消す処理すりゃいいんじゃない?
2024/09/08(日) 23:08:52.84ID:zGDX69KT0
そんな前提は無い
2024/09/08(日) 23:17:36.18ID:zRsEDrHt0
toastとかOS標準のnotificationを使えばいい
キーボードショートカットも用意されてる
2024/09/08(日) 23:26:26.06ID:zGDX69KT0
win11toastもinputがあってさえフォーカスは来てないな
2024/09/08(日) 23:46:26.14ID:zGDX69KT0
結局、powershellのPopupをsubprocess.runで呼び出すのがベスト
それで可能なのは最初から判ってたけども

os寄りの処理って互換性とか無視してosべったりで作った方が幸せになれる
2024/09/09(月) 05:00:01.20ID:i0341ZB+0
そこはWin32APIを呼び出したほうが親和性が高いだろう
windowsアプリと同じ見てくれ、ふるまいになるし、
デフォルトボタンやフォーカスは確実に有効にできる
2024/09/09(月) 14:54:53.83ID:iWr3h1fB0
中央だと邪魔だから端に表示するような種類のポップアップで強制的にフォーカス奪っだらダメだろ
個人専用なら好きにすればいいが他人に使わせるアプリでは絶対やってはいけないパターン
2024/09/09(月) 15:25:57.69ID:M6TEicyP0
ポップアップの位置を変えるようなことは、Win32 API使っても無理な気がする
標準に似せたものを自前で作るしか
914デフォルトの名無しさん (ワッチョイ 8aa5-f0zi)
垢版 |
2024/09/09(月) 17:58:31.91ID:XsanjNXu0
WindowsアプリをPythonで作るな!
2024/09/09(月) 19:59:54.08ID:WqKgF9CS0
カラスの勝手でしょぉ♪
916デフォルトの名無しさん (アウアウエー Sa52-t/33)
垢版 |
2024/09/09(月) 21:10:41.86ID:6U3TxPzTa
ただでさえPOPUPはTOPMOSTにしない方が良いのに
TOPMOSTにした上でENTERで反応するPOPUPなんて百害あって一理無しよ
2024/09/09(月) 21:29:34.03ID:M6TEicyP0
謎にエスパーされてるけど、topmostが目下の課題
powershellからWScript.ShellのPopupを呼び出すと、
フォーカスは奪ってくれるけどtopmostではない
全画面で動画見てると音はするけど視覚的には気付かない
フォーカスがあってかつtopmostというのがやりたい処理なのに
2024/09/09(月) 21:33:40.24ID:+To1Amul0
表示はOSの通知にして
EnterはUIにフォーカスさせるのではなくキー入力をジャックする
2024/09/09(月) 21:40:36.79ID:wEgLJ8040
きっとそのうちEnterで消すのがうざくなる…
2024/09/09(月) 22:59:51.52ID:i0341ZB+0
>>917
"ctypes.windll.user32.MessageBoxW"で
MB Typeに"0x40000"を与えれば"MB_TOPMOST"になる

>>914
普段はコンソールを立ち上げずにこっそり実行
エラーとか、対話が必要なときだけポップアップが出るようにするのには有用なんだよ
no_consoleモード+ポップアップはそんな目的にはぴったりだし
2024/09/09(月) 23:24:20.06ID:M6TEicyP0
0x40000足せばいいだけだったのか
もう殆ど手が届いてたんだな
262144でかすぎひん
2024/09/09(月) 23:50:28.10ID:M6TEicyP0
bit毎に意味があるんじゃなくて、nibble毎に割り振ってるんだな
不思議な設計
2024/09/10(火) 09:46:51.62ID:V/5rRVOx0
bit毎に意味あるだろ
bit fieldでググってこい
924デフォルトの名無しさん (アウアウエー Sa52-t/33)
垢版 |
2024/09/10(火) 13:11:16.09ID:KGjTz1X0a
+で良いと思ってる人間と|だろうなと思ってる人間は雲泥の差がある
2024/09/10(火) 21:10:56.22ID:sQRxeMB30
>もう殆ど手が届いてたんだな
これジョークじゃなきゃキッツいな
926デフォルトの名無しさん (ワッチョイ aaae-voeu)
垢版 |
2024/09/13(金) 14:57:50.02ID:HD5QYSk40
OpenAIが複雑な推論能力をもつAIモデル「OpenAI o1」と「OpenAI o1-mini」を発表、プログラミングや数学で高い能力を発揮
https://gigazine.net/news/20240913-openai-o1/
2024/09/13(金) 15:23:01.98ID:Ri3tNWi30
>>926

すごいな
天才プログラマーか
2024/09/13(金) 21:29:13.87ID:jtrlU5c10
何かあった時に失われるのが嫌なので、
ログとか出力する時に1行毎にopenして書いて閉じてるけど、
flush=True を付けるのと違いあるんだろうか
2024/09/13(金) 21:34:14.83ID:jtrlU5c10
違いあるんだろうかシリーズ
リストをソートしたいと思った時、ふつーに
l = sorted(l)
と書いたけど、そういえば l.sort() という方法もあった
気持ち悪いので本能的に避けたいけど、わざわざ用意されてるメリットって何だろう
計算コストは同じな気がする
2024/09/13(金) 22:31:20.25ID:C+esSXth0
同じじゃない
くだすれ行け
931デフォルトの名無しさん (ワッチョイ f9bf-BHET)
垢版 |
2024/09/13(金) 22:35:10.99ID:3+j4DpP00
>>929
一般的には追加のメモリ確保をしない l.sort() の方が効率的
l を再代入してるから分かりにくいけど、ソート結果は元の l とは別の領域に作られてる
これは、k = sorted(l) と書いた時にソート前後の両方のリストがオブジェクトとして存在することからも分かると思う
(l = sorted(l) は、追加のリストを作ったあとに l の参照先を新しいものに置き換えてる)

l.sort() だと元々あった l の領域内でソートされるので、追加のメモリ確保がいらない

要素数が小さいと気になることは無いと思うけど、例えば要素が10万個とかある場合だとだいぶ差が出ると思う
2024/09/13(金) 23:01:27.70ID:jtrlU5c10
メモリ確保するのってそんなに重い処理なの?
933デフォルトの名無しさん (ワッチョイ f9bf-BHET)
垢版 |
2024/09/13(金) 23:50:13.06ID:3+j4DpP00
>>932
一般的には重い処理
とはいっても、小さな量だと問題にならない
例えば画像処理の分野で、HDや4Kサイズの画像を1000枚処理したいといった話だと、メモリを毎回確保するか一度だけ確保したものを使い回すかで処理時間はだいぶ変わる (体感できるくらいに)
2024/09/13(金) 23:57:27.00ID:jtrlU5c10
なるほどー
Cの時点でmallocが具体的に何してるか知らんしな
既に連続した空き容量があって割り当てるだけなら一瞬だろうけど、
いろいろ地上げしたり大変なんだろう
2024/09/14(土) 00:15:53.13ID:ed1VLorT0
まとまった容量ならsbrk()使えって言われなかった?
2024/09/14(土) 00:43:58.26ID:uwwiah/a0
メモリ確保はO(n)でソートは下手したらO(n^2)だから、
nが大きいほどトータル処理時間に占めるメモリ確保の割合はむしろ小さくなるのでは
2024/09/14(土) 02:05:41.53ID:xMffrK+40
>>936
その2つのnは全く別のものだろ
アホか
2024/09/14(土) 06:27:04.06ID:uwwiah/a0
nが小さい場合:
メモリ確保の比率は大きいけどどうせ一瞬だから気にしない
nが大きい場合:
メモリ確保にも時間かかるけど、ソート時間が圧倒的だから気にしない

結局、気分の問題だけど、
破壊的な操作が嫌とか言ったらappend()とかできないし、
ミュータブルはそういうものと思うしか
939デフォルトの名無しさん (ワッチョイ f99f-BHET)
垢版 |
2024/09/14(土) 07:44:59.11ID:c0KErmyP0
ソートのコストとメモリ確保のコストは別々にかかるものだし、減らせるなら減らした方が良いと思う
自分のプログラムが扱うデータが小さくてsortedでもほぼ変わらないなら、こちらでも良い
自分も書き方自体は sorted の方が好きだし小さいプログラムならこちらを使ってるけど、そこは好みの問題なのでお好みで
940デフォルトの名無しさん (アウアウエー Sa52-t/33)
垢版 |
2024/09/14(土) 13:33:03.30ID:o3f0Ddoea
l.sort() はみみっちい領域でやりくりする分アルゴリズムは遅くなりそう
l = sorted(l) あるいは k = sorted(l) が富豪的で結果的に速い可能性はある
2024/09/14(土) 14:16:06.35ID:tQni2TQM0
メモリ使いまくりはキャッシュ効率下がるから
一律に富豪が強いとは限らない
使うしかない時は強いけど
2024/09/14(土) 14:50:34.43ID:aiF3uBwH0
>>940
可能性無いよ
sorted()は内部でlist.sort()の実装を呼び出してる

ざっくり言えば
new_list = list(original_list)
new_list.sort()
return new_list
2024/09/14(土) 16:15:00.42ID:uwwiah/a0
for item in sorted(l):
とやるよりも
l.sort()
for item in l:
の方が速い、みたいな話

明示的にしろ暗黙にしろ、オブジェクトのコピーにいちいち気を使いたくない
コピーするだけで時間がかかるようなオブジェクトになりそうなら、
最初からそうならない実装にする
2024/09/14(土) 19:29:07.00ID:WN+ppFgMr
seleniumのxpathについて質問です
5chの書き込み欄のxpathを確認し、
driver.find_element(By.XPATH, '//*[@id="js-postform_message"]').click()
と書いたのですが、プログラムを実行するとxpathが存在しないパターンの動作をしてしまいます
ブラウザでF12キーを押し、書き込み欄をクリックしてxpathをコピーするというよくある方法を使っているのですが、これではダメなんですかね?
2024/09/14(土) 19:38:44.99ID:uwwiah/a0
driver.page_source を保存しておいて解析する
2024/09/14(土) 19:50:56.07ID:uwwiah/a0
書き込みボタンは
//*[@id="js-postform_submit"]
で、
//*[@id="js-postform_message"]
は書き込み欄なので、clickではなくsend_keys
2024/09/14(土) 20:01:37.67ID:reS5hF+Mr
ありがとうございます
send_keysは別の行にあります
一応clickの部分は行ごと消しましたがやはりダメですね…
2024/09/14(土) 20:51:28.72ID:reS5hF+Mr
エラーをちゃんと見られるようにしたら、
name 'By' is not defined
と出ました
また要素関係の書き方が変わったんですかね?
以前は上記の
driver.find_element(By.XPATH, '//*[@id="js-postform_message"]')
という書き方で動いていたのですが…
書き方変更などの情報はどこで入手するのか…
2024/09/14(土) 20:56:59.72ID:hpW9Sln40
from selenium.webdriver.common.by import By
2024/09/14(土) 20:58:25.69ID:reS5hF+Mr
>>949
ありがとうございます!解決しました!
それをコメントアウトしてしまっていました…
2024/09/16(月) 15:32:29.19ID:JFhhEPMwd
pandasやべえな
マジで融通効かねえ
おなえらよくこんなもん使ってるな
2024/09/16(月) 15:33:30.66ID:JFhhEPMwd
pandasに持っていくのは最終工程だな
2024/09/16(月) 15:45:45.85ID:5ZHFYrcP0
df.loc('name')
じゃなくて
df.loc['name']
なのが中身どうなってんのと思う

これはプロパティだからと言われてそんなもんかと思ってたけど、
別に角括弧はプロパティの特徴じゃないし
2024/09/16(月) 16:18:34.31ID:64X1rAF60
df.locが返すインスタンスに__getitem__が定義されてる
955デフォルトの名無しさん (ワッチョイ 57b4-18DD)
垢版 |
2024/09/16(月) 17:26:32.35ID:oHCpo/jD0
>>951
そう?
融通効かない処理は普通にリストとかに変換したり、iterrowsしたりすれば大体できて、
95%のやりたいことのほとんどはpandasで用意されてるメソッド・関数でできる気がするけど
2024/09/16(月) 18:17:47.48ID:qB1csSl90
pandas使う職業って何?
バックエンドエンジニアとか?
2024/09/16(月) 18:46:53.38ID:7NWwbbi+0
学生です
2024/09/16(月) 19:14:36.94ID:sHL0iTWh0
かぐる
とかデータサイエンス
2024/09/16(月) 19:40:30.88ID:5ZHFYrcP0
データ渡すと加工して文字列にしてくれる関数名
make, create, generate どれがいいだろう
2024/09/16(月) 19:52:09.23ID:7NWwbbi+0
それら候補でいうならどれでもよくって
どういう文字列を生成するか説明できる修飾が大事かな
2024/09/17(火) 09:30:50.73ID:mIyBA525d
同意
むしろ俺なら動詞なしで「どういった文字列か」を表す名詞だけにしたい
962デフォルトの名無しさん (アウアウエー Sadf-N1Zj)
垢版 |
2024/09/17(火) 10:19:17.42ID:TMGdiCOOa
>>959
convert
963デフォルトの名無しさん (アウアウエー Sadf-N1Zj)
垢版 |
2024/09/17(火) 10:20:30.50ID:TMGdiCOOa
>>951
Pandasは行指向じゃなくて列指向だと判ればあとは簡単
964デフォルトの名無しさん (アウアウエー Sadf-N1Zj)
垢版 |
2024/09/17(火) 10:23:43.89ID:TMGdiCOOa
>>943
>明示的にしろ暗黙にしろ、オブジェクトのコピーにいちいち気を使いたくない
>コピーするだけで時間がかかるようなオブジェクトになりそうなら、
>最初からそうならない実装にする

まあこれは真実で
それならオブジェクトを保持するためのオブジェクトと
ソートするためだけのインデックスを分けるかな
2024/09/17(火) 10:55:41.47ID:rwC9vNLN0
pandasはもう古いよ
polarsがついにv1公開されたからそれに移行した
loc["name"]みたいなのも消えてる
というよりインデックスというゴミが消えてる
966デフォルトの名無しさん (ワッチョイ ff32-uXkv)
垢版 |
2024/09/17(火) 10:56:23.24ID:bvtQXCJ00
複数のエクセルファイルから特定列のデータを抜き出して
新たにエクセルファイルにまとめて書き出すということをしたのですが、
複数ファイルには重複する行が含まれていて、
下記の2つを試したのですがどちらも欠損データが生じました。

1.listに一旦全部入れて、最終的にsetに一旦変換してlistに戻す
2.1行ごとに最終的なリストに含まれていない要素をチェックしながら追加

データは5列で最終的に重複処理したもので300行程度、
重複処理前でも2000行余りぐらいのデータです。
最終的にpandasで全部一旦追加した後df.drop_duplicates()にて処理して問題なく処理されたのですが
下記の方法で欠損することとかあり得るのでしょうか?
2024/09/17(火) 12:11:47.72ID:rwC9vNLN0
>>959
data2str
2024/09/17(火) 12:16:27.92ID:rwC9vNLN0
>>966
各列をそれぞれlistにしてsetにしたのか?
それだと各列ごとに重複削除するから行レベルでは重複してないものも消えそうだが
969デフォルトの名無しさん (ワッチョイ ff32-uXkv)
垢版 |
2024/09/17(火) 13:30:30.55ID:bvtQXCJ00
>>968
1,2とも各行””.joiin(list)してから処理しています。
2024/09/17(火) 14:23:18.11ID:5SGUmRCR0
>>962
処理内容はconvertだけど、目的語が元データになってしまう
convert_to_newdata
にしないと、
convert_newdata
だと絶対間違う
2024/09/17(火) 14:53:19.06ID:ifJb33l00
>>969
["1", "", "2", "", "3"]と["1", "2", "3", "", ""]は重複?
とりあえずtuple(list)してから処理してみれば?
2024/09/17(火) 14:58:45.05ID:ifJb33l00
>>967
こういう命名をするとよくわかるように「データ渡すと加工して文字列にしてくれる関数名」というふわっとした問題設定がそもそも間違ってる可能性が高い
2024/09/17(火) 15:55:41.11ID:bvtQXCJ00
>>971
基本空白は入っていないので["1", "2", “3”]の形式になりますが
元がexcelなのでデータを見ると何かが混じっている可能性はありますね
少し余裕が出たら検証してみます
2024/09/17(火) 16:40:41.16ID:5SGUmRCR0
人間用excelを読み込むと全然ちゃんとしてないので、
全セルを配列に読み込んで、文字列検索でタイトル行を探して、
データ範囲らしき部分を割り出して、それでもエラーは出るのでいろんなケースに対応して、
みたいなひたすら泥臭いコードになる
取り消し線で削除するのやめて
975デフォルトの名無しさん (ワッチョイ ff32-uXkv)
垢版 |
2024/09/17(火) 18:07:41.72ID:bvtQXCJ00
上の方でpolarsを知ったので、ちょっと試してたのですがやり方がわかりません。
2つのDFを比較して、A,B列の値が共通の場合新しい方のDFの行を使ってDFを作成するということがやりたいです。

以下のpandasの処理をpolarsでやりたいときどのようにしたら良いんでしょう?

filtered_df = dfOLD[~(dfOLD[“A”].isin(dfNEW[“A”]) & dfOLD[“B”].isin(dfNEW[“B”]))]
concat_df = pd.concat([dfNEW, filtered_df], axis=0, ignore_index=True)
2024/09/17(火) 18:29:39.94ID:ifJb33l00
>>973
空白は一つの例だよ
他にもtuple(list)で比較するのと"".join(list)で比較するのでは結果が異なるケースあるでしょ

それに今現在処理してるデータにそういうケースが含まれてるかどうかを調べるよりも
まずは要求仕様として列を連結した文字列が同じなら重複としてみなすのかどうかが大事

みなす仕様ならdf.drop_duplicates()を使うのは間違ってる
みなさない仕様なら"".join(list)で比較するのは間違ってる
2024/09/18(水) 05:40:32.41ID:X/am8lpR0
>>956
飼育員とか
2024/09/18(水) 10:09:46.84ID:cY7mpOqC0
自己レスです。意外とあっさり出来ました。> 975
import polars as pl
df1 = pl.DataFrame({"a": ['A1','A2','A3','A4'], "b": ['B1', 'B2', 'B3', 'B4'], "c": ['100', '200', '300', '400']})
df2 = pl.DataFrame({"a": ['A1','A2','A3'], "b": ['B1', 'B2', 'B3'], "c": ['150', '250', '350']})
filterDF = df1.join(df2, on=['a','b'], how="anti")
concatDF = pl.concat([df2, filterDF])
print(filterDF,concatDF)
2024/09/18(水) 19:08:32.27ID:6/+t/jhb0
単位の数Uがあって、nとUに対して
int(n/U)*U
を返す関数はどういう名前がいいだろう
2024/09/18(水) 20:05:30.82ID:EisHWYAH0
floor/round_down/align + (to +) unit/multiple
2024/09/18(水) 20:09:46.82ID:pnKtz9DD0
discretizeとか?
2024/09/18(水) 21:47:38.42ID:pnKtz9DD0
音楽ソフトなんかでは
拍子の位置に揃えるのを
quantizeって言うな
2024/09/18(水) 22:23:17.78ID:9wk3LXWe0
n//U*Uと(n+U-1)//U*Uが区別できる命名にしたいね
984デフォルトの名無しさん (ワッチョイ 577c-18DD)
垢版 |
2024/09/19(木) 18:45:28.76ID:WvuWfkM50
>>979
普通はtruncateじゃない?SQLにTRUNC関数がある
2024/09/19(木) 19:05:10.19ID:Cti+u+u60
MATLABのfloor(x, unit)と同じだからfloorだろう
2024/09/19(木) 19:26:31.64ID:dEupb3oa0
floorか
整数へのfloorはunit=1の特殊ケース
レス数が950を超えています。1000を超えると書き込みができなくなります。
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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