くだすれPython(超初心者用) その39 at TECH
[2ch|▼Menu]
1:デフォルトの名無しさん
18/08/24 07:50:35.97 VD4/++xS.net
このスレッドは、他のスレッドでは書き込めない超低レベル、
もしくは質問者自身何が何だか分からない質問を勇気を持って書き込むスレッドです。
へび使いが優しくコメントを返しますが、お礼は Python の布教と初心者の救済をお願いします。
エラーを解決したいときはエラー表示や環境(バージョン/IDE or command line)を略さずに書き込んで下さい。
騙りが頻発しています。質問する方は一時的なトリップをつけることを検討して下さい。
次スレは >>985 辺りで
前スレ
くだすれPython(超初心者用) その38
スレリンク(tech板)

2:デフォルトの名無しさん
18/08/24 07:50:54.90 VD4/++xS.net
◆関連リンク Python の Home Page
URLリンク(www.python.org)
◆長いコードはこういうところにはってください
URLリンク(ideone.com)
URLリンク(codepad.org)
URLリンク(pastebin.com)
URLリンク(dpaste.com)
URLリンク(try.jupyter.org)
◆まとめwiki
URLリンク(python.rdy.jp)

3:デフォルトの名無しさん
18/08/24 11:55:16.20 ZVlysGry.net
ストロー廃止

4:デフォルトの名無しさん
18/08/24 16:34:04.92 RSpOEB9t.net
『日経ソフトウェア2018年7月号』
「新連載 金融データをPythonで分析してみよう」p.050-
のとおりにやってみてここまではうまく行ったのですが、
ここで
>>> ts.RateBid.diff().round(3).sort_values().dropna().unique()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python3/dist-packages/pandas/core/generic.py", line 1843, in __getattr__
(type(self).__name__, name))
AttributeError: 'Series' object has no attribute 'sort_values'
「Seriesオブジェクトはsort_valuesなんてアトリビュートを持ってないよ」
というエラーをPython3.4.2が吐き出しました。(´


5:Eω・`) ただそれだけ。書いてみたかっただけです。それじゃまた。



6:デフォルトの名無しさん
18/08/24 16:59:48.14 O0T9h+Ku.net
>>4
日経ソフトウエアって読む価値ありますか?(゚Д゚)?

7:デフォルトの名無しさん
18/08/24 22:42:39.09 J2z8mB41.net
環境整えてみたんですが
いざなにを作ればいいんですか?

8:デフォルトの名無しさん
18/08/24 22:55:45.28 A0MvxlLt.net
自分探しの旅みてーな疑問だな

9:デフォルトの名無しさん
18/08/25 04:28:11.12 gxBSyOuw.net
日経ソフトウエアは、読む価値なし
日経Linux、WEB+DB、Software Design などは良い

10:sage
18/08/25 09:53:53.61 XgYSdCc9g
Ubuntu 18、UTF-8環境、Python 3.6.5です。
PHP(こっちもUTF-8)から引数を受け取ってPyhonで処理するプログラムを作っています。まずPHP側で
$arg = '日本語1 日本語2';
$cmd = 'python3 python.py "'.$arg.'"';
exec($cmd, $output);
とやって、python.pyで
import sys
a = sys.argv[1]
b = a.split(' ')
#listhoge{'日本語1': 0, '日本語2': 1,.....}
c = listhoge[a[0]]
で「日本語1は0」という結果を得たいのですが、
c = listhoge[a[0]]のところで
KeyError: '\udce6\udc97\udca5\udce6\udc9c\udcac\udce8\udcaa\udc9e1'
となってしまいます。
c = listhoge['日本語1']
なら、cは期待通り0が代入されます。
print(a)
#日本語1 日本語2
print(a[0])
print(a[1])
#日本語1
#日本語2
で、引数自体は受け取れているようなのですが、
if a[0] == '日本語1':
    print('OK')
else:
    print('NG')
の結果は「NG」です。
listhogeに正しく値を渡すには、どうしたらよいでしょうか。ご教示よろしくお願いします。

11:9
18/08/25 10:43:20.77 lc6+Z78bq
すみません。a[0].a[1]としているところは、正しくはb[0].b[1]でした。
で、b[0] == 日本語1にならず困っています

12:デフォルトの名無しさん
18/08/25 10:02:26.96 H9tlLYtz.net
Ubuntu 18、UTF-8環境、Python 3.6.5です。
PHP(こっちもUTF-8)から引数を受け取ってPyhonで処理するプログラムを作っています。まずPHP側で
$arg = '日本語1 日本語2';
$cmd = 'python3 python.py "'.$arg.'"';
exec($cmd, $output);
とやって、python.pyで
import sys
a = sys.argv[1]
b = a.split(' ')
#listhoge{'日本語1': 0, '日本語2': 1,.....}
c = listhoge[a[0]]
で「日本語1は0」という結果を得たいのですが、
c = listhoge[a[0]]のところで
KeyError: '\udce6\udc97\udca5\udce6\udc9c\udcac\udce8\udcaa\udc9e1'
となってしまいます。
c = listhoge['日本語1']
なら、cは期待通り0が代入されます。
print(a)
#日本語1 日本語2
print(a[0])
print(a[1])
#日本語1
#日本語2
で、引数自体は受け取れているようなのですが、
if a[0] == '日本語1':
print('OK')
else:
print('NG')
の結果は「NG」です。
listhogeに正しく値を渡すには、どうしたらよいでしょうか。ご教示よろしくお願いします。

13:デフォルトの名無しさん
18/08/25 10:17:20.53 5go0Mg15.net
>>11
a[0]は日でa[1]は本
if b[0] == "日本語1":
にすればいい

14:デフォルトの名無しさん
18/08/25 10:38:37.45 H9tlLYtz.net
>>12
すみません!コードを抽象化するときに書き間違えました。
a[0].a[1]のところは、正しくはb[0].b[1]です。
せっかく教えていただいたのにすみません。
b[0]を日本語1と評価されるようにするにはどうしたらよいでしょうか。

15:デフォルトの名無しさん
18/08/25 10:53:10.81 5go0Mg15.net
>>13
日本語1の1が全角とか?
b[0]の出力をそのまま
b[0]== の後にコピペしてもfalseになるの?

16:デフォルトの名無しさん
18/08/25 11:10:46.62 H9tlLYtz.net
>>14
コピペで試しているので、文字列は同一だと思います。
今、試しにコマンドラインでスクリプトに引数を渡すと、コンソール上では期待通りの動作をしました。
PHPからだと、print出力的には同一に見えるけど別なデータになっているということでしょうか

17:デフォルトの名無しさん
18/08/25 11:31:58.85 5go0Mg15.net
>>15
PHPから受け取ったのがstrじゃなくてbyte型なのかな?type()で調べてみたら?

18:デフォルトの名無しさん
18/08/25 11:46:56.88 kfh++Yrt.net
必要なとこだけコピペで貼ってくれ

19:デフォルトの名無しさん
18/08/25 11:50:43.54 H9tlLYtz.net
>>16
type(b[0])
だと何も返ってこないのですが、
type(b[0] is str)
だとTrueが返って来ます

20:a
18/08/25 12:11:07.51 ieXJ7jC8V
android エミュレーター mumu で簡単自動周回
URLリンク(ankulua.boards.net)

21:デフォルトの名無しさん
18/08/25 13:02:46.63 H9tlLYtz.net
>>17
すみません。これでいかがでしょうか。
PHP 7.2
$cmd = 'python3 python.py "日本語1 日本語2"';
exec($cmd, $output);
Python 3.6.5
# coding: utf-8
import sys
listhoge = {"日本語1":0, "日本語2":1}
a = sys.argv[1]
b = a.split(' ')
c = listhoge[b[0]]
error.log
Traceback (most recent call last):
File "python.py", line 23, in <module>
c = listhoge[b[0]]
KeyError: '\udce6\udc97\udca5\udce6\udc9c\udcac\udce8\udcaa\udc9e1'

22:デフォルトの名無しさん
18/08/25 14:30:45.41 kfh++Yrt.net
>>20
文字コード不一致してね?
LANG=xxx python3 python.py "日本語1 日本語2"
とかで、ロケール設定して実行してみたら?

23:デフォルトの名無しさん
18/08/25 14:50:58.87 H9tlLYtz.net
>>21
動きました! ありがとうございます!
system localeはLANG=ja_JP.UTF-8だったので、そこは疑ってませんでした。

24:デフォルトの名無しさん
18/08/25 18:14:21.70 P/kKO950.net
また今日も天才に救われた人が居るな、解決おめでとう!

25:デフォルトの名無しさん
18/08/26 01:55:23.42 TJFxEnkY.net
プログラム初学者ですが、入門書を買って勉強しております。
複合代入演算子の項を見ていたら1点疑問があり、
who = '猫'
text = ''
text += '吾輩は'
text += who
text += 'である。'
print(text)
これ本では2行目の''が大事だと書かれているんですが、省略して

who = '猫'
text = '吾輩は'
text += who
text += 'である。'
print(text)
とするのはだめなのでしょうか?
初歩的な質問ですみません。

26:デフォルトの名無しさん
18/08/26 02:11:05.36 xGLfO5+N.net
>>24
text += 'XXX'
で形が揃うから見やすいとかコピペや順序入れ替えが楽って以外の意味はないと思う
というか理由が書いてないならあまり良くない入門書だな
3.6以降ならf-stringを使って
text = f'我輩は{who}である'
のほうが良さげ
URLリンク(atsuoishimoto.hatenablog.com)

27:デフォルトの名無しさん
18/08/26 02:24:57.28 TJFxEnkY.net
>>25



28:ありがとうございました。URL参考になりました。 入門書はいろいろ調べてみたんですけどやはり周りに修学者がいないと選びにくいですね。



29:デフォルトの名無しさん
18/08/26 04:17:09.95 L324XJEs.net
みんなのpythonって本はプログラム知識が殆ど無い入門者にお勧めできますか?
本屋で立ち読みしようと思ったんですけど無くて、アマゾンで調べたら評価はまちまちみたいで…

30:デフォルトの名無しさん
18/08/26 07:36:47.56 w0D5YFHr.net
この2冊は、既にプログラミングが出来る人向け。
数言語は知っていて、Ruby, Python を学ぶ人向け
たのしいRuby 第5版、2016
みんなのPython 第4版、2017
以下の本は、プログラミング初心者でも読める。
スッキリわかる Java入門 第2版、2014
知らないけど、progate のサイトで勉強すれば?

31:デフォルトの名無しさん
18/08/26 07:44:31.55 KclbjBGL.net
>>24
同じように動くという意味では問題無い。

著者としては空の変数を定義することで
変数の宣言と値の代入を分離したかったんじゃないかな?
pythonでは変数を明示的に宣言だけすることはできないから、

32:デフォルトの名無しさん
18/08/26 07:49:32.68 KclbjBGL.net
>>27
合うか合わないかは人によるから
kindleでお試し読んでみたら

33:デフォルトの名無しさん
18/08/26 07:58:14.06 L324XJEs.net
>>28
スッキリわかるjavaはやりました
なのでその次に読む本として選んでみました。大丈夫そうですか?
簡単だと良いんですが

34:25
18/08/26 09:57:49.56 w0D5YFHr.net
読む順番としては、先に「たのしいRuby」を3回読むと、
「みんなのPython」が楽に読める
「みんなのPython」を先に読むと、内容が薄くて、現実味が無いかも。
つまり、よくわからない
たのしいの方が、正規表現とか、内容が濃い

35:デフォルトの名無しさん
18/08/26 10:32:43.51 L324XJEs.net
>>32
そうなんですね。みんなのpythonの方が表紙にでっかく絵が書いてあったり
堅苦しい内容じゃなさそうで入門向けで良いのかなって思ったんですが内容ないんですね…
わかりました。たのしいruby買います。アドバイスありがとうございます

36:デフォルトの名無しさん
18/08/26 12:18:03.60 Y1vMA8RK.net
>>33
そいつは有名なruby荒らしだぞ。
python勉強するのになんでruby本読む必要があるんだよ。よく考えろ

37:デフォルトの名無しさん
18/08/26 17:39:56.34 O9adGcKd.net
もうrubyをNGしてもいいぐらい

38:デフォルトの名無しさん
18/08/26 18:15:35.15 wR7TFJf0.net
ガイジに優しくしよう

39:デフォルトの名無しさん
18/08/26 19:59:11.67 7VGl0ROF.net
脈略のないrubyコードの貼り付け、ruby本の紹介は禁止ってテンプレに入れておいてくれ

40:25
18/08/26 23:41:34.26 w0D5YFHr.net
Ruby, Python, JavaScript というのは、単なる各言語の文法書。
プログラミングの本じゃない
オブジェクト指向・クロージャ・スコープ・this などの概念を、学べるわけではない。
文法書を読んでも、プログラミングは出来ない
文法書を読むとプログラミングができると、ほとんどの奴は勘違いしているけど、
「みんなのPython」を読んでも文法がわかるだけで、プログラミングが出来るようにはならない
「たのしいRuby」「スッキリわかる Java入門」などを読んで、
自分でクラスを派生させたり、CSVファイルを読み書きしたり、
Sinatra をいじくりまわしたり悪戦苦闘しながら、プログラミングを学ぶ
プログラミングを学ぶ部分は、Pythonじゃなくてもよい。
いじくりまわすのには、Rubyが最も簡単
プログラミングを学ぶには、各言語の「Effective 何々」という本を読む。
これは、プロの必須本。
文法書の次のレベルへ行かないと、プログラミング自体を学べない

41:デフォルトの名無しさん
18/08/27 00:26:43.00 lvpUeXXJ.net
Rubyは衰退していくだけのオワコン言語だから手を出したら負け組だよ

42:デフォルトの名無しさん
18/08/27 00:53:03.94 HhBAi2Wr.net
Rubyみたいなオワコン言語の話は余所でやれ

43:デフォルトの名無しさん
18/08/27 02:33:22.67 +WOcodwf.net
スクリプトのやり方教えて下さい
認識できないって出るんですけど…

44:デフォルトの名無しさん
18/08/27 03:15:17.22 yTR9Y+Mn.net
>>27
プログラミング未経験でオライリーの入門Pythonを買ってがんばってる
今のところついていけてるけど、
みんなのPythonはきっとイラストや絵が入ってて紙面もカラーなんだろうなって考えるとうらやましい
こっちは絵もイラストも全くないです

45:デフォルトの名無しさん
18/08/27 03:17:20.38 yTR9Y+Mn.net
早速躓いた
>>29
変数

値の代入
ってとうちがうんですか?

46:デフォルトの名無しさん
18/08/27 03:21:04.08 yTR9Y+Mn.net
プログラミング自体を学ぶのにこれはどうですか?
初めてのプログラミング
URLリンク(www.oreilly.co.jp)
PythonじゃなくてRubyで説明されてるみたいなんですけど

47:デフォルトの名無しさん
18/08/27 06:12:09.02 ba8BcfX3.net
与えられた2つの数値から、最小公倍数・最大公約数を求めてみろ

48:デフォルトの名無しさん
18/08/27 07:06:23.18 A3+vkFVR.net
>>44
pythonなら「独学プログラマーーpython」がある。

49:デフォルトの名無しさん
18/08/27 07:25:20.50 fqwvA6xk.net
スタートブックとかの方が分かりやすいんじゃないの?
プログラム初心者なら

50:デフォルトの名無しさん
18/08/27 12:18:58.34 Q4eMB8Ps.net
>>45
互除法

51:デフォルトの名無しさん
18/08/27 21:06:47.86 KW/ftoFq.net
subprocessについてなんですが、
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
import sys
import subprocess

dl = subprocess.run(["radigo", "rec", "-a=JP13", "-id=QRR", "-s=20180827200000"], stdout=subprocess.PIPE)
sys.stdout.buffer.write(dl.stdout)
上記のような場合、変数を引数の一部として渡すにはどうやるんですか?
以下だと{proglamId}という文字列として外部コマンドに送られてしまってダメでした。
area = 'JP13'
ch = 'QRR'
proglamId = '20180827200000'
dl = subprocess.run(["radigo", "rec", "-a={area}", "-id={ch}", "-s={proglamId}"], stdout=subprocess.PIPE)
sys.stdout.buffer.write(dl.stdout)

52:デフォルトの名無しさん
18/08/27 21:26:41.39 6eK9kwOU.net
>>49
>>> proglamId = '20180827200000'
>>> f'-s={proglamId}'
'-s=20180827200000'

53:デフォルトの名無しさん
18/08/27 21:33:33.15 KW/ftoFq.net
>>50
どうもありがとうございます。
2行目はfフォーマットって言うんですかね?それを使っていると思うんですが、46のsubprocessの中ではどう書くんでしょうか?

54:デフォルトの名無しさん
18/08/27 21:56:03.71 KW/ftoFq.net
>>51
出来ました。
パターン1
area = 'JP13'
ch = 'QRR'
proglamId = '20180827200000'
dl = subprocess.run(["radigo", "rec", f'-a={area}', f'-id={ch}', f'-s={proglamId}'], stdout=subprocess.PIPE)
パターン2
area = 'JP13'
area = f'-a={area}'
ch = 'QRR'
ch = f'-id={ch}'
proglamId = '20180827200000'
proglamId = f'-s={proglamId}'
dl = subprocess.run(["radigo", "rec", area, ch, proglamId], stdout=subprocess.PIPE)
sys.stdout.buffer.write(dl.stdout)



55:チちがスマートな書き方ですか?



56:デフォルトの名無しさん
18/08/27 23:29:37.66 KW/ftoFq.net
muxx = subprocess.run(["muxer", f'-i input.aac?sbr', f'-o output.m4a', f'--optimize-pd', f'--file-format m4a'], stdout=subprocess.PIPE)
sys.stdout.buffer.write(muxx.stdout)
とやると、muxerコマンドからは
Error: you specified invalid option: -i input.aac?sbr.
と返ってきてしまいます。
muxx = subprocess.run(["muxer", "-i input.aac?sbr", "-o output.m4a", "--optimize-pd", "--file-format m4a"], stdout=subprocess.PIPE)
sys.stdout.buffer.write(muxx.stdout)
これでも上記と同じエラーになり、
muxx = subprocess.run([f'muxer -i input.aac?sbr -o output.m4a --optimize-pd --file-format m4a'], stdout=subprocess.PIPE)
sys.stdout.buffer.write(muxx.stdout)
これだとPythonがエラーになってしまいました。
Usageは
muxer [global_options] -i input1 [-i input2 -i input3 ...] -o output
です。
コンソールで以下のようにやると正常に動いてくれます。
$ muxer -i input.aac?sbr -o output.m4a --optimize-pd --file-format m4a
何がいけないんでしょうか?

57:デフォルトの名無しさん
18/08/28 00:20:33.07 TEJeUOom.net
端末で入力すると、シェルが、? の機能を動かすけど、
subprocess で、プロセスを直接起動すると、
シェルが介入しないから、? が展開されないとか?

58:デフォルトの名無しさん
18/08/28 00:26:18.50 wjmNvrcp.net
>>54
?sbrの部分を省いてもエラーは改善しなかったです

59:デフォルトの名無しさん
18/08/28 05:00:41.28 PEha72vP.net
shell=true
とかは? と muxer なんて知らないくせに適当に言ってみる

60:デフォルトの名無しさん
18/08/28 05:07:01.91 PEha72vP.net
ん?
その前に
stdout=subprocess.PIPE)
sys.stdout.buffer.write(muxx.stdout)
の部分って必要なの?

61:デフォルトの名無しさん
18/08/28 08:35:42.53 M3D05fOs.net
>>53
もちろんrunの第一引数が悪い
"-i"と"input.aac"を分けろ

62:デフォルトの名無しさん
18/08/28 08:36:39.19 skYXWt6l.net
>>53
上2つは "-i input.aac?sbr" がオプションとして認識されてそう。'-i', f'input.aac?sbr' とかで分けてくれ
3つ目は shell=True で動く(/bin/sh -c 'muxer ....' と展開される)
シェルインジェクションとかあるので、お作法として shell=True はあまり使わないほうがいいかな
詳しくはマニュアル参照
>>52
書き方は好みだからなんとも言えんなー俺ならこんな感じで書く
arg = 'hoge'
cmd = f'bash tst_cmd.sh {arg}'
resp = subprocess.run(cmd.split(), stdout=subprocess.PIPE)
スペース入りファイル名とか使うなら、パーサー作って食わすかな
import csv
def CMD_PARSER(cmd):
....return list(csv.reader([cmd], delimiter=' ', quotechar='"'))[0]
arg = 'hoge foo'
cmd = f'bash tst_cmd.sh "{arg}"'
resp = subprocess.run(CMD_PARSER(cmd), stdout=subprocess.PIPE)

63:デフォルトの名無しさん
18/08/28 08:39:26.15 M3D05fOs.net
空白が混じってると
> 一般に、引数のシーケンスを渡す方が望ましいです。なぜなら、モジュールが必要な引数のエスケープやクオート
> (例えばファイル名中のスペースを許すこと) の面倒を見ることができるためです
によってエスケープされるので意図通りにシステムコールに渡らないわけだな

64:デフォルトの名無しさん
18/08/28 10:16:39.79 wjmNvrcp.net
みなさんどうもありがとうございます
>>58
>>59
>>60
「-i ファイル名」の形式で書かないといけないので「-i」と「ファイル名」で分けて書くという頭が全くなかったです。
muxx = subprocess.run(["muxer", "-i", "input.aac?sbr", "-o", "output.m4a", "--optimize-pd", "--file-format", "m4a"], stdout=subprocess.PIPE)
と分けて書くとうまくいきました。
>>56
>>59
shell=trueについて調べてみます
>>57 この書き方だとsubprocess.callとsubprocess.check_callとsubprocess.check_outputの3つがまとめて出来るらしいのでこれで書きました



66:デフォルトの名無しさん
18/08/28 14:55:03.72 WFu4qQCr.net
find関数で
line.find('a')だと部分一致で返してくれるんですが
c=input() aと入力して
line.find(c)とすると完全一致でしか返してくれないんですがどうすればいいですか

67:デフォルトの名無しさん
18/08/28 16:02:01.79 eDasHWl3.net
んなこたぁない。

68:デフォルトの名無しさん
18/08/29 09:39:33.95 t35BnR1i.net
python3m ってなんですか?

69:デフォルトの名無しさん
18/08/29 10:09:58.87 zNgJ3vFs.net
住友と関係が?

70:デフォルトの名無しさん
18/08/29 17:38:59.31 zHN7x4pt.net
xmlの属性を指定する場合、以下のどっちも同じ答えを返してくれるんですが、どっちで書くのがいいんでしょうか?
パターン1
duration1 = int(root.attrib["dur"])
print(duration1)
パターン2
duration2 = int(root.get("dur"))
print(duration2)

71:デフォルトの名無しさん
18/08/29 19:50:21.16 +JD/mPB3.net
BeautifulSoup前提で喋ってます?
もしそうなら、属性が存在する限りどちらでもよい
getは属性が存在しないときNoneを返すが、attribはそうではない
まあ試してみ

72:デフォルトの名無しさん
18/08/29 19:54:41.40 zHN7x4pt.net
>>67
どうもありがとうございます
xml.etree.ElementTreeです
たしかに存在しない場合の挙動は違ってました

73:デフォルトの名無しさん
18/08/29 21:03:23.42 LyGOIS06.net
すいません日付の計算で疑問なんですが、
aaa_date_str = '2018-08-29 20:00:00'
bbb_date_str = '2018-08-29 19:00:00'
aaa_date = datetime.datetime.strptime(aaa_date_str, '%Y-%m-%d %H:%M:%S')
bbb_date = datetime.datetime.strptime(bbb_date_str, '%Y-%m-%d %H:%M:%S')

として、
date_diff = aaa_date - bbb_date
print(date_diff.days)
--> 0
になりますが、逆にすると、
date_diff = bbb_date - aaa_date
print(date_diff.days)
--> -1
になります。
差異が1日に満たなければゼロになるのかと思いきや
計算結果が負だとゼロにならずに-1になるのがなんか疑問です。
それとも記述に問題あるでしょうか。

74:デフォルトの名無しさん
18/08/29 21:09:31.82 GQLl9uCt.net
>>69
3.0-3.1=-0.1だろう?0じゃないだろう?
そういうこった

75:デフォルトの名無しさん
18/08/30 10:23:36.80 S/vwwZyF.net
int()とかと一緒か
[0.5]=0
[-0.5]=-1

76:デフォルトの名無しさん
18/08/30 21:55:04.51 hf8/OGEv.net
>>70
すいません、分からず…
逆に、3.1 - 3.0 = 0.1 はdaysだと0になるんです。
>>71
int()だと、正も負も小数点以下切り捨てではないですか?

77:デフォルトの名無しさん
18/08/30 21:59:01.86 Ffnu7dR5.net
>>72
68が言ってるようにたぶん四捨五入なんだず

78:デフォルトの名無しさん
18/08/30 21:59:56.98 Ffnu7dR5.net
おっと 1時間でも -1ってでるのか
じゃあ
時間は切り捨てじゃなくて四捨五入でもなくて切り上げになってんだ

79:デフォルトの名無しさん
18/08/30 22:19:45.36 Ffnu7dR5.net
おっと
おれのうしろで
おれのいもうとが
「そのマイナス1はエラー値であって 数値じゃない diff.daysはぬるぽしない」
といっている

80:デフォルトの名無しさん
18/08/30 22:29:53.78 Ffnu7dR5.net
それから
なぜ print(date_diff)してみないんだ
ともいっている

81:デフォルトの名無しさん
18/08/30 22:42:08.44 Ffnu7dR5.net
おれは
aaa_date + date_diff
をためしてみてから、
timedeltaについての説明を読みに行くことを最終的におすすぬする。

82:デフォルトの名無しさん
18/08/30 23:01:55.56 TEO8FkA/.net
別マシンで書いたスクリプトを動かそうとしたら
dateutilが無いと言われ実行出来ません。
スクリプトにはこう書きました。
from dateutil.relativedelta import relativedelta
動いたマシンのPythonのバージョンは3.6.4、
動かないマシンのPythonのバージョンは3.6.5です。
dateutilはどこで入手するんでしょうか?

83:デフォルトの名無しさん
18/08/30 23:04:27.25 TEO8FkA/.net
すみません
pip で dateutilsを入れたら使えました。

84:デフォルトの名無しさん
18/08/31 04:09:39.70 rWvqNQHt.net
python 3.6
windows10
import pyautogui
pyautogui.rightClick(100,100)
pyautogui.moveRel(10,10)
と書くと右クリックのあとマウスが動いてくれない。
これはライブラリのバグ?

85:デフォルトの名無しさん
18/08/31 04:37:56.39 rWvqNQHt.net
ごめん動いてた

86:デフォルトの名無しさん
18/08/31 09:38:10.61 cxARIA2x.net
罰としてお前の


87:ヒ起という突起をクリックしてやる



88:デフォルトの名無しさん
18/08/31 19:38:51.59 IH56D7c/.net
Dropboxの共有リンクを取得したいです。
dropbox.Dropbox(トークン).sharing_create_shared_link
を使うと、例えば
PathLinkMetadata(url='URLリンク(db.tt)', visibility=Visibility('public', None), path='/hoge/hage.jpg', expires=None)
こういう1行が出力されます。
sharing_create_shared_link以外の関数で、
URLリンク(db.tt)だけを出力する関数ってありますか?
続く

89:デフォルトの名無しさん
18/08/31 19:39:30.70 IH56D7c/.net
sharing_create_shared_linkだと、以下のようになります。
import dropbox
dbxTOKEN = 'DROPBOX_MY_ACCESS_TOKEN'
dbxRemotePath = f'/aiueo/hage.jpg'
dbx = dropbox.Dropbox(dbxTOKEN)
dbx.users_get_current_account()
# アップロード
f = open(dbxLocalPath, 'rb')
dbx.files_upload(f.read(),dbxRemotePath)
f.close()
# 共有リンクの取得
dbxLink = dbx.sharing_create_shared_link(dbxRemotePath,short_url=True) # Dropbox から共有リンクを取得
dbxLink = str(dbxLink)[17:-1] # 整形 「PathLinkMetadata(」と「)」を除外
dbxLink = dbxLink.split(',') # リストに変換
dbxLink = dbxLink[0] # リストの1番目 (url)
dbxLink = str(dbxLink)[5:-1] # 整形
print(dbxLink)
URLリンク(db.tt) # プリントされたurl
つづく

90:デフォルトの名無しさん
18/08/31 19:40:14.75 IH56D7c/.net
文字列を分割してその中の一部を取り出す方法ですが、
PathLinkMetadata(url='URLリンク(db.tt)', visibility=Visibility('public', None), path='/hoge/hage.jpg', expires=None)
こういう1行があったとして、
url='URLリンク(db.tt)',
visibility=Visibility('public', None),
path='/hoge/hage.jpg',
expires=None
こんなふうに分割したいです。
split(',')でやるとpublic', Noneここのコンマでも反応してしまいます。
今回はurlの取得が目的なので今の所実害は無いんですが、もっと簡単にdorpboxの共有リンクを取得したり確実な文字列の分割方法を知りたいです。

91:デフォルトの名無しさん
18/09/01 12:32:11.32 Z1lBiRzX.net
>>85
ずいぶん遠回りしてるけど、
a=dropbox.Dropbox(トークン).sharing_create_shared_link
として、
a.url
を参照すれば良いのでは?
他についても
a.path とかで参照できるはず

92:デフォルトの名無しさん
18/09/01 15:22:01.82 5RO4iQNV.net
すいません、ハマって困っています。
utf-8のテキストファイル(内容は'1'という文字のみ)を、python3の以下のスクリプトで
読み込んで、整数に変換しようとすると、以下のエラーが出て困っています。
Traceback (most recent call last):
File "collect_progress.py", line 75, in <module>
num = int(str)
ValueError: invalid literal for int() with base 10: '\ufeff1'
ユニコードの文字列は整数変換できないのでしょうか。
fr = open("sample.txt")
str = fr.readline()
num = int(str)

93:デフォルトの名無しさん
18/09/01 15:26:08.43 VfnjVYeD.net
BOMついてないか

94:デフォルトの名無しさん
18/09/01 15:37:12.61 kUpkBQ3x.net
echo 1 | ruby -e 'STDIN.each { |line| puts(line.to_i + 1) }'
Ruby なら、シェルから、1-liner で、2 と出力される
Python でも同じように、1-liner でやってみれば?

95:デフォルトの名無しさん
18/09/01 15:55:11.65 A/mNPeDe.net
>>87
open("sample.txt", encoding="utf-8-sig")
> いくつかの領域では、UTF-8 でエンコードされたファイルの先頭に "BOM" を利用する習慣があります;
中略
> もし、そのようなファイルを読む場合には、この印を自動


96:的にスキップするために 'utf-8-sig' コーデックを利用してください。 https://docs.python.org/ja/3/howto/unicode.html#reading-and-writing-unicode-data



97:デフォルトの名無しさん
18/09/01 16:02:39.43 kUpkBQ3x.net
プログラムでは、BOMなしUTF-8 (UTF-8N)を使った方が無難
その代わり、Windows のExplorer ではテキスト検索できなくなるから、
Windows10・WSL・Ubuntu から、grep してる

98:デフォルトの名無しさん
18/09/01 16:30:27.70 eWdCnGo4.net
>>86
どうもありがとうございます!
.urlなどで簡単に取り出せました。
これはdropboxのライブラリの機能でしょうか?

99:デフォルトの名無しさん
18/09/01 16:55:46.47 5RO4iQNV.net
>>88, 86, 87, 88
ありがとうございます。
BOMが原因でした。
恥ずかしいことに、BOMというのは全く知りませんでした。
助かりました。

100:デフォルトの名無しさん
18/09/01 20:51:46.35 5sfxmNQl.net
>>92
まあそうだと思う。
自分はDropboxライブラリを使ったことはないけど、>>83を見ると戻り値としてPathLinkMetadataオブジェクトが返ってきていて、属性としてurlとかpathとかがある事がわかった(これはpython的に考えればわかる)
使うメソッドとかについてはドキュメント読むと今回みたいなことはすぐ分かるだろうし、勉強にもなるよ

101:デフォルトの名無しさん
18/09/01 23:59:25.43 eWdCnGo4.net
>>94
.sharing_create_shared_linkはドキュメントの中で見つけた関数なんですが、英語分からないから試行錯誤していました
ありがとうございます

102:デフォルトの名無しさん
18/09/02 05:35:01.36 0w6R8dvF.net
Python初心者(プログラミング初心者)です。
スクレイピングをしようとしていたら躓いてしまったので質問をさせてください。
requestsで変数htmlに入れたサイトのhtmlをファイルに保存したいのですが良く分かりませんでした。
file.writeみたいなのも書いてみてるんですがエラー吐かれたりします。誰か例として作ってくれませんか?
requests.getで変数htmlに取得したサイトhtmlをc:/user/hoge/Documents/hymlfile.htmlに追記モードで保存したいです。
無能でごめんなさい助けてください。

103:デフォルトの名無しさん
18/09/02 07:13:26.28 5WqNet32.net
File.open(file_path, 'a') { |io| io.write text }
Ruby では、File.open の引数に、
ファイルパスと、ファイルを開く際の、mode を渡す
a なら追記書き込み
「python file write」で検索!

104:デフォルトの名無しさん
18/09/02 08:24:22.51 GLq4HnWW.net
import requests
r = requests.get("URLリンク(www.python.org"))
f = open("c:/user/hoge/Documents/hymlfile.html", "a")
f.write(r.text)

105:デフォルトの名無しさん
18/09/02 09:00:47.26 0w6R8dvF.net
>>98
てゃんks
無事解決しました本当にありがとう
やっと眠れtる

106:デフォルトの名無しさん
18/09/02 16:47:00.30 RE+xVvI9.net
f.write(r.text)
UnicodeEncodeError: 'cp932' codec can't encode character '\U0001f5a5' in position 12657: illegal multibyte sequence
スクレイピングしたサイトに絵文字があると(?)このエラーが起こるようです。
エンコーディングの関係だと思うんですけど対処法分かる方いますか?
UnicodeEncodeErrorで調べたら解説しているところが少し見つかったんですが僕には何が言いたいのかさっぱりでした。。。。

107:デフォルトの名無しさん
18/09/02 16:56:55.96 RE+xVvI9.net
f.openの時にencoding='utf-8'渡したら解決しました!!
うれしい!!!ありがとう

108:デフォルトの名無しさん
18/09/02 16:59:32.33 5WqNet32.net
cp932 はやめて、BOMなしUTF-8(UTF-8N)で書き込めば?
それか、エンコード


109:変換できない文字は、 エラーにせずに、? に置き換えるとか



110:デフォルトの名無しさん
18/09/02 17:49:53.80 B4IY8jcq.net
ElementTree、lxml、BeautifulSoupってそれぞれどう違うの?

111:デフォルトの名無しさん
18/09/02 17:51:26.55 B4IY8jcq.net
ElementTreeは純正
lxml、BeautifulSoupはサードパーティ
lxmlは高速だけど、動的なサイトに弱い
BeautifulSoupは比較的簡単
って感じ?

112:デフォルトの名無しさん
18/09/02 19:12:56.97 dvfcpVZJ.net
何が言いたいのか

113:デフォルトの名無しさん
18/09/02 19:26:55.59 /VgxTU/I.net
開けっ放しにするんはいけんよ

114:デフォルトの名無しさん
18/09/02 20:28:17.67 NdoNeabl.net
lxml 言う程速さを感じないんだよな

115:デフォルトの名無しさん
18/09/03 01:13:17.00 IUTdxFc1.net
import requests
from lxml import etree
url = URLリンク(example.com)<) height="60" width="60"alt="ふじこ"></td> </tr></table><br />
<br /> あいうえお<br />かきくけこ
<br /><br /> 番組Webサイト:<a href="URLリンク(example.com) />
メッセージフォーム:<a href="URLリンク(example.com) />
<br /></div>
がプリントされます。(投稿できなかったので途中で改行してます)
次に、本文はどうやって取り出すんでしょうか?

116:デフォルトの名無しさん
18/09/03 01:49:47.20 BfF9DJB1.net
要素の内側のテキストを収集するためには、itertext() を参照してください。例えば "".join(element.itertext()) のようにします。

117:デフォルトの名無しさん
18/09/03 19:12:05.50 ttVcJTrG.net
Ruby のNokogiri なら、CSS セレクター・XPath とか
jQuery でも、CSSセレクター

118:デフォルトの名無しさん
18/09/06 00:43:50.19 YKdnoVr6.net
```python
hstg = info.get('hashtags')
print(hstg)
# hashtag
p_url = info['url']['short']
```
p_urlの行をget()だとどう書けばいいですか
辞書にアクセスした時存在しないキーだとNoneを返したいんでget()を使いたいんですが

119:デフォルトの名無しさん
18/09/06 01:06:41.32 9wgcxN1e.net
ようわからんが
info.get('url', {}).get('short')
とか?
若干無駄があるがこの程度の無駄が気になる神経症はCでも書いとけ

120:デフォルトの名無しさん
18/09/06 02:03:26.11 YKdnoVr6.net
>>112
どうもありがとうございます!
試してみます。
{}の中に'short'が入るイメージでしょうか?

121:デフォルトの名無しさん
18/09/06 14:42:12.77 tPMc56fx.net
馬鹿はオウム返しですぐ次の質問するよね

122:デフォルトの名無しさん
18/09/06 15:13:17.47 QdhwFBW3.net
python 3.6.3
tkinter でファンクションキーを押したら文字列を表示させたいです
def text _desp(event):
  label["text"] ="bcdef"
label =tk.Label(root, text ="aaaaa", )
label.bind('<F1>', text_desp)
label.pack
と書いて、表示したウィンドウをアクティブにしてからF1を押してもtextが入れ替わりません
原因は何でしょうか?

123:デフォルトの名無しさん
18/09/06 16:49:56.62 ntAiYVJq.net
インタプリタ言語最強

124:デフォルトの名無しさん
18/09/06 17:12:39.45 QdhwFBW3.net
>>115
rootにbindしたらいけました
すみません

125:デフォルトの名無しさん
18/09/06 18:22:16.04 t3mpF7WK.net
VSCodeの「ターミナルで選択範囲/行を実行」って機能をよく使うんですけど
作ってる最中のfor文内(1行目がインデントしてるテキスト)をテストしたいときは
インデントを一時的に消して実行するしか無いんですかね?
IPythonなら1行目がインデントしてても実行してくれるけど
あれはターミナルにフォーカスを移してEnterを押さないと


126:タ行してくれないのが不満だし



127:デフォルトの名無しさん
18/09/06 18:56:40.11 r2CzgwVn.net
馬鹿はオウム返しって言うの好きだよね

128:デフォルトの名無しさん
18/09/06 19:24:48.49 UI2giREj.net
VSCode の拡張機能のCode Runner を入れたら、
右クリックメニューから、そのまま実行できる
または、選択したコードを実行できる

129:デフォルトの名無しさん
18/09/06 21:13:55.88 fyvsaEga.net
入門書で学んでるプログラミング初学者です。
数字以外を入力した場合に「不正な値です」と表示させたいのですが計算を間違えた際にも「不正な値です」と出てしまいます。
どこを直したらいいでしょうか?
from random import randint
miss = 0
correct = 0
print("問題?3回間違えたら終了。qで終了")
while miss<3 :
a = randint(1,100)
b = randint(1,100)
ans = a + b
question = f" {a} + {b} は?"
value = input(question)
#qと入力されたら終了
if value == "q":
break
#正解か不正解か判断する
if value == str(ans) :
correct += 1
print("正解です!")
elif type(value) != int :
print("不正な入力です。")
else :
miss += 1
print("間違い!","×" * miss)
print("----終了----")
print("正解 :", correct)
print("間違い:", miss)

130:デフォルトの名無しさん
18/09/06 21:16:02.79 r2CzgwVn.net
当っとるからええやん

131:デフォルトの名無しさん
18/09/06 21:16:08.52 fyvsaEga.net
あれ、書き込みにインデントが反映されてない…

132:デフォルトの名無しさん
18/09/06 21:33:42.86 rG7JeulO.net
>>123
ソース貼れるサイト
URLリンク(pastebin.com) ペーストビン
URLリンク(ja.osdn.net) OSDNコピペ ログインしないで投稿すると一週間で自動削除
>>1

133:デフォルトの名無しさん
18/09/06 21:46:28.09 r2CzgwVn.net
>>121
真面目に添削すると
数字意外を入力した場合に「不正な値です」と表示する
→数字でないならそもそも値ではないやんか、何言っとんやわれ?なめとんか?
「不正な入力です」と表示する
→不正というワードは否定形なのでわかりにくい
「間違った入力です」と表示する
→何が間違っているのかわからない
「数字以外の入力です」と表示する
→だからどうすれば良いのかわかりにくい
「数字を入力してください」と表示する
→漢数字でもええんか?
「答えになる数値を入力を入力してください」と表示する
→めっちゃわかりやすいやん!

134:デフォルトの名無しさん
18/09/06 21:56:28.45 bpm1lb7O.net
>>121
assert使うといいよ

135:デフォルトの名無しさん
18/09/07 00:32:30.89 hV93LKBw.net
>>124
すみません。テンプレ読み直します。
>>125
ありがとうございます。何気にすごく重要なことを教えてもらった気がする。
>>126
試してみます。

136:デフォルトの名無しさん
18/09/07 16:30:33.98 DKf48tK4.net
>>125
イイネ!(・∀・)ワロタヨ!

137:デフォルトの名無しさん
18/09/07 17:07:52.42 82uhpEUK.net
>>121
valueはstrだから、たとけ入力されたのが"123"とかの数'字'であってもtypeはstrになる
つまり、自分で明示的に型変換をしない限り何を入力してもtype(value)==intが成り立つ事はない
入力を受け取ったらまず最初にvalueをintに型変換したら?
int(value)でできるし、変換できない文字列が入って来たらエラーになるので例外処理で不正な入力も検知できるよ

138:デフォルトの名無しさん
18/09/07 17:26:59.78 po/zaTpZ.net
たとけ

139:デフォルトの名無しさん
18/09/07 18:10:30.75 DKf48tK4.net
たとけ

140:デフォルトの名無しさん
18/09/07 18:16:00.07 QgSvA/nW.net
とたけけ

141:デフォルトの名無しさん
18/09/07


142:20:30:20.91 ID:DKf48tK4.net



143:デフォルトの名無しさん
18/09/08 02:42:10.64 zJ7GwxeF.net
import dataset
db = dataset.connect('sqlite:///zoo.db')
table = db['zoo']
results = table.find(damages = '大けが')
# for record in results:
# print(record)
if results == None:
print('無いです')
else:
print('ありました')
print(results)

カラムの 『damages』 が 『大けが』 のレコードがあるか無いか知りたいんですが、当たり前だけどこれだとダメでした。どうやってあるかないかを調べたらいいんでしょうか?

144:デフォルトの名無しさん
18/09/08 03:07:51.29 zJ7GwxeF.net
自己レスです。
これで出来たっぽいけど他にもっといいやり方ありますか?

import dataset
db = dataset.connect('sqlite:///zoo.db')
table = db['zoo']
results = list(table.find(damages = '大けが'))
# for record in results:
# print(record)
if results == []:
print('無いです')
else:
print('ありました')
print(results)

145:デフォルトの名無しさん
18/09/08 07:56:53.17 aeU58kvm.net
>>129
丁寧にありがとうございます。
なるほど…例外処理でやってみます。

146:デフォルトの名無しさん
18/09/08 08:21:40.63 BJl7Ln5g.net
こんにちは。
pycharm という便利なものがあるとのことでさっそく使ってみました。
最新版の"PyCharm Community Edition 2018.2.3"をWindows 10 にインストールし、
プロジェクトの設定の"Existing interpreter"に、普段使用している cygwin64 の "python3.6m.exe"を
指定しました。IDEからRunすると問題なく実行されるのですが、ブレークポイントを設定して
Debugを実行すると、
pydev debugger: warning: trying to add breakpoint to file that does not exist: /cygdrive/c/pycharm_doc/test001/c:/pycharm_doc/test001/main.py (will have no effect)
という、ファイルが存在しないというエラーが出来ます。
cygwinのパスの表現と、windowsのパスの表現が合体した変なパス名が表示されます。
3台のPCで試したのですが、全部同じ結果でした。解決する方法はありますかねぇ。
(こちらの都合でcygwin環境が必須になっています)


次ページ
最新レス表示
スレッドの検索
類似スレ一覧
話題のニュース
おまかせリスト
▼オプションを表示
暇つぶし2ch

1104日前に更新/299 KB
担当:undef