|....,,__ |_::;; ~"'ヽ | //^''ヽ,,) | i⌒" | ∀`) < 誰もいない きのこるならいまのうち |⊂ | ノ _,,,......,,__ /_~ ,,...:::_::;; ~"'ヽ (,, '"ヾヽ i|i //^''ヽ,,) ^ :'⌒i i⌒" |( ´∀`) < きのこ のこーのこ げんきのこ ♪ |(ノ |つ | | ⊂ _ ノ ""U _,,,......,,__ /_~ ,,...:::_::;; ~"'ヽ (,, '"ヾヽ i|i //^''ヽ,,) ^ :'⌒i i⌒" (´∀` )| < エリンギ まいたけ ブナシメジ ♪ ⊂| (ノ | | | ヽ _ ⊃ .U"" | | ミ | ミ サッ! | ミ |
┌─┐ │●│ └─┤ _ ∩ ( ゚∀゚)彡 ┌─┬⊂彡 │●│ おっぱい!おっぱい! └─┘
いちもつ
1乙
6 :
デフォルトの名無しさん :2013/01/22(火) 05:00:11.00
_ _ ∩ ( ゚∀゚ )ノ ))) おっ! ( 二つ ノ 彡ヽ (_ノ ⌒゙J ⊂ヽ ((( (_ _ )、 ぱい! γ ⊂ノ, 彡 し'⌒ヽJ _ _ ∩ ( ゚∀゚ )ノ ))) おっ! ( 二つ ノ 彡ヽ (_ノ ⌒゙J ⊂ヽ ((( (_ _ )、 ぱい! γ ⊂ノ, 彡 し'⌒ヽJ
>>6 2コマ目と4コマ目がワキ嗅いでる臭くて嫌だな〜なんて
前のスレッドが1000に達したので書き込みなおします。よろしくお願いします。 コマンドプロンプトで値を与えると、リストのリストのデータができあがります。 いろいろな値をコマンドプロンプトで与えてそれを一つのテキストファイルに出力するには、どうすればよいのですか? リストのリストの出力の例 例1 L1 = [["みかん"]["50円"][C][D]],["りんご"]["100円"][G][J]],......] 例2 L2 = [["ぶどう"]["400円"][C][D]],["りんご"]["100円"][G][J]],......] 欲しいテキストファイル みかん,50円,C,D りんご....... ....... 例1の終わり ぶどう,50円,C,D ...... ....... 例2の終わり 3つめの始まり
>>9 >>> L1 = [["みかん"]["50円"]['C']['D']],["りんご"]["100円"]['G']['J']]]
File "<stdin>", line 1
L1 = [["みかん"]["50円"]['C']['D']],["りんご"]["100円"]['G']['J']]]
^
SyntaxError: invalid syntax
L1, L2書き直し
あと、データ構造自体が悪いと思う
正確には分からないけど、L1, L2のデータ構造見直しが重要だと思う。
>>10 ごめんなさい。データ構造は以下のようになります。
L1 = [["みかん","50円",'C','D'],["りんご","100円",'G','J']]
>>11 WindowsXPではこれで行けた
with open('outfile.txt','w') as f:
for youso in L1:
f.write(','.join(youso) + '\n')
L1 = [["みかん","50円",'C','D'],["りんご","100円",'G','J']] path = 'tech9.txt' with open(path, 'w') as f: for line in L1: f.write(','.join(line) + '\n') :!cat tech9.txt みかん,50円,C,D りんご,100円,G,J
コマンドプロンプトからの入力が示されていないのだが大丈夫か
オッケー
lines = [] print('空文字列でしたら、終了します。') while True: raw = input('文字列を入力して下さい。:') # 文字列前後の空白文字、改行文字を除去。 line = raw.strip() if not line: # 空文字列だったので終了。 break # 空白文字で個々の要素に分割。 elements = line.split(' ') lines.append(elements) path = 'tech9-2.txt' # 書き込みmodeで path を開く。 with open(path, 'w') as fw: for elements in lines: # ','を区切り文字として、結合 csv = ','.join(elements) # 書き込み。 fw.write(csv) # 改行文字を書き込み。 fw.write('\n') # with 使って open() を呼び出しているから、 # fw.close()を呼び出して file object を閉じる必要はない。 # with open(path, 'r') as fr: # 上と下は同じ意味。 with open(path) as fr: # さっき書き込んだ内容全てを読み込む。 rdata = fr.read() # 読み込んだ内容を 'rdata =' の出力以下に書き込む。 print('rdata =') print(rdata)
>>12 ,13,16
できました。ありがとうございます。
list = [[0,1,T, ”文字列”][1,2,E,” 文字列”][1,2,E,][3,4,S, ” 文字列”][4,-1,L, ” 文字列”]] for i in range(len(list)): if list[i][2] == 'S' or list[i][2] == 'L' or list[i][2] == 'T' or list[i][2] == 'E': a = list[i][2] b_num = list[i][1] for i in range(len(list)): if b_num == list[i][0]: a += list[i][2] a_list.append(a) うまくいきません。 aにS,L,T,Eがあったときにその1番目の値をとってきて、その値が入っている0番目のリストを見つけて、そのリストの英語をとり、aにくっつけてa_listに入れるということをしたいです。 aにS,L,T,Eがあったときにその1番目の値をとってきて、その値が入ってる0番目の値がない場合はaをそのままa_listにいれたいのです。 出力結果としては a_list = [TE,E,E,SL,L]が欲しいです。 よろしくお願いします。
訂正 list = [[0,1,T, ”文字列”][1,2,E,”文字列”][1,2,E, ”文字列”][3,4,S, ” 文字列”][4,-1,L, ”文字列”]] です。
>>11 csvモジュール使おう
ideone.com/hGegPp
>>18-19 各要素の数が同じならループ変数に展開できる。簡略化するけど、こんな感じ
src = [(0,1,"T"), (1,2,"E"), (1,2,"E"), (3,4,"S"), (4,-1,"L")]
dest = []
for a,b,c in src:
if c in "TESL":
v = c + "".join(z for x,y,z in src if x == b)
dest.append(v)
>>18 期待する出力は ['TEE', 'E', 'E', 'SL', 'L'] ではなくて?
インデント推測でコードを修正したら、ロジック自体は通ったよ。
エラーの原因
* リストの形式はカンマ区切り [[1][2][3]] のようになってるのを [[1],[2],[3]] とする。
* 文字列のクォートが全角っぽいので半角に直す。
* T,E,S,L が未定義。
他、気になる所
変数名、組み込み型の"list" や ループ変数の "i" を使いまわしてる点。
このコードの実行には影響ないけど、問題になりやすいので避けたほうがいい。
20の補足 最初の条件式のところは、一文字と決まってるなら c in "TESL" で済むけど、 "ES" in "TESL" 等も真になってしまうので、できればsetの利用を推奨。
>>20 ,21,22
ありがとうございます。
>>21 最初のTが2つのEにかかるのですが、同じものにかかる場合は、一つにかかると判定したいです。
なので
['TE', 'E', 'E', 'SL', 'L']
が欲しいです。
>>23 順序関係ないならsetが使える
順序が必要なら、順序を維持したまま重複を取り除く関数を作る。手軽/手抜きな実装は、
from collections import OrderedDict
uniq = lambda seq: OrderedDict.fromkeys(seq).keys()
他
ideone.com/Ah77EZ if/forで率直に実装
ideone.com/VBH065 イテレータを扱う場合、重複した要素を取くジェネレータを作っておくと便利
入力となるテキストファイルが以下のように書かれています。 文。文。文。文。文。文。〜「A」はBでした。文。文。文。文。文。文。 (K) 文。文。文。文。文。文。文。文。文。「G」はHでした。 文。文。文。文。文。文。〜 (C。それは「Dである。」)〜。文。 (J) (E。それは「Fである。」)〜。文。文。文。文。文。文。文。 ある形になっている文をとってきたいのですが、 テキストファイルをラインごとに読み込んだあとに、それを。で区切って読みなおして、『「,」は,でした。』が含まれる文をとってくればいいのでしょうか? 文をとるところまでが上記の方法でよいとしてそこから抜き出すのはどうすればよいでしょうか? 『〜「A」はBでした。』、『〜 (C。それは「Dである。」)〜。』、(J)という形の文を全てとって来たいです。 その後にAとBとCとDを抜き出したいです。 欲しい出力は 「A」はBでした。、「G」はHでした。 A、B、G、H (C。それは「Dである。」)、(E。それは「Fである。」) C、D、E、F (J)、(K) J、K です。(と「は全角です。
正規表現使ったほうがよくね
>>26 Pythonより自然言語処理寄りな話題かも
「わかち書き」「形態素解析」辺りを調べてみよう。
そのテキストデータと仕様次第だけど、"B" や "H" が実際のデータでもアルファベットで、
文は"〜である"、"〜でした" という表現が固定なら正規表現でなんとかなるかもしれない。
実際には、日本語の文中から名詞を抜き出したいのなら、適切な自然言語処理が必要になってくる。
>テキストファイルをラインごとに読み込んだあとに、それを。で区切って読みなおして これだけだと、文中の改行・括弧内の句点の読み飛ばしに対応出来ない。 ["〜 (C。", "それは「Dである。", "」)〜。"] と離れてしまう。 括弧のみの行は句点が無いので、(行読みの場合なら)行内に単一で現れないと、 他の文の先頭に付いて混ざってしまうかもしれない、等。 この辺、例に挙げられたデータが簡略化されすぎてて、不確定な点が多く判断が難しいけど。 この例では大丈夫でも、実データでうまくいかない可能性がある。
JKです、まで読んだ。
31 :
デフォルトの名無しさん :2013/01/26(土) 16:49:09.18
CSVファイルを扱う勉強をしているのですが、わからないところがあります。 reader= csv.reader( hoge) for i, v in enumerate( reader): if i == 9: break として、readerをforで10回回したとします 次にもう一度forで回すと、CSVが11行目から取り出されます。 これはどうしてこうなるのでしょうか? イテレータの内部で現在までに吐き出した値を覚えておいてその続きから呼び出されているのでしょうか? もう一度、csv.reader()で代入すると1行目から回ることはわかりましたが、一般的なメソッドか何かで初期化が用意されているのでしょうか?
hogeにファイルライクオブジェクト渡してるだろ そいつでseekできんじゃね
>これはどうしてこうなるのでしょうか? >イテレータの内部で現在までに吐き出した値を覚えておいてその続きから呼び出されているのでしょうか? イテレータが保持していると言うよりは、csv.readerに渡したファイルライクオブジェクトが状態を保持している それはなぜかと言ったら、全てのデータを必要とするかどうか分からないのに全読みしておく価値がないから
全読みしておく価値がない+すでに読み取ったデータが再利用される保証もない
正規表現で『「A」はBでした。』を抜き出してみようと、以下を実行してみたのですが、うまくいきません。 何がいけないのでしょうか? #coding:utf-8 import re pattern = re.compile(r'「.*でした。') file = open('a.txt','r') for line in file: matchedList = pattern.findall(line) if matchedList: print matchedList file.close()
>>36 まずは、どのようにうまくいかないかをきちんと説明しよう
多分 a.txtの文字コードだと思うけど。
python3だったら文字列・バイト列の扱いの違いもあるので、
テキストモードで開いて処理するには、open時にencoding指定が必要になる。
>>33 > イテレータが保持していると言うよりは、csv.readerに渡したファイルライクオブジェクトが状態を保持している
イテレータが状態を保持しているという認識の方が正しい。
>>31 > これはどうしてこうなるのでしょうか? イテレータの内部で現在までに吐き出した値を覚えておいてその続きから呼び出されているのでしょうか?
その通り。というか、イテレータはそもそもその目的のためにある。
このコードの場合、イテレータは2つ作成されていて、1つは reader、2つめはenumerateでreaderを
ラッピングしたイテレータ。どちらもStopIterationしてないので、for を抜けた後も継続可能。
> 一般的なメソッドか何かで初期化が用意されているのでしょうか?
イテレータを途中で初期化する方法は普通はない。
この場合、hoge.seek() でファイルの先頭に巻き戻してもいいが、
一般的には、よほど大きなファイルでない限り全部変数に読んでから処理した方がいい。
ちなみに、csv.readerにはline_num属性があるので、enumerateする意味はあまりない。
>>37 Python2の最新バージョンを使っています。
エラーは出なく、何も表示されずにプログラムが終了します。
>>40 a.txtの文字エンコーディングは?
UTF-8, UTF-16, Shitf_JIS, EUC-JPとかそういうの
>>41 Shitf_JISです。
UTF-8に直すべきでしょうか?
先におかしな頭を直すべき
>>40 > if matchedList:
> print matchedList
findall( ) の戻り値って文字列の(* リスト *) じゃないの?
なので、
for m in matchedList:
print m
かと。
あと、compile( ) って、マニュアルには match( ) と search( ) に適用って書いてあるけど、
findall( ) にも使えるんだっけ?
>>43 うちでは動いたよ
考えられるのはa.txtとスクリプトのエンコーディングが一致してないか
そもそもa.txtが正規表現 「.*でした。 にマッチする文字列を含んでいないとか
ちなみに次のスクリプトならどうなる?
#coding:utf-8
import re, codecs
pattern = re.compile(ur'「.*でした。')
for line in codecs.open('a.txt','r', 'utf-8'):
matchedList = pattern.findall(line)
if matchedList: print matchedList
ああ仕様変更したんだっけ。全角空白でインデントするから置換してね import re, codecs pattern = re.compile(ur'「.*でした。') for line in codecs.open('a.txt','r', 'utf-8'): matchedList = pattern.findall(line) if matchedList: print matchedList
import re, codecs pattern = re.compile(ur'「.*でした。') for line in codecs.open('a.txt','r', 'utf-8'): matchedList = pattern.findall(line) if matchedList: print matchedList
>>46-48 動きました。
ありがとうございました。
(ur'「.*でした。') でuを付ける必要があったんですね。
>>49 uが必要なのは codecs.open で開いたから、読み込み時にunicodeへデコードされる為。
元のコード、うちでも期待通りに動いたよ。(python2.7/a.txtの文字コードはutf-8で試した)
原因は、テキスト・ファイルと正規表現の文字コードの不一致と診て間違いなさそう。
後、オフトピ。正規表現 ur'「.*?でした。' と最短一致が必要になるはず。
スクリプトファイル自身の文字コードが 動作に重大な影響を及ぼすのっていうのは スクリプト言語の重大な欠点だよね。 自分もWindowsのメモ帳が何のコードでテキストを 保存するかを知らないまま、職場でスクリプトを書いている。 書くのも実行するのもWindows環境である限り 問題ないのだろうけど、将来不安ではある。
>>50 原因まで、わかりやすく説明してくれてありがとうございます。
最短一致を使用すると出力が出てこなくなってしまいます。
どういうことか教えていただけませんか?
「A」はBでした。
『「.*」は.*でした。』で目的の出力を得ることができました。
C。それは「Dである。」
『.+。それは「*である。』
が一つの文の中で何個か出てくる場合があって、目的の出力が取れなくて困っています。
この時に最短一致が必要ということでしょうか?
両方とも?をつけてもうまくいきません。
訂正 『.+。それは「.*である。』 です。
>>51 Sublime Text2くらい使いなよ
すいません。?を両方とも、2個つけてもちゃんと出力されました。 ただやっぱり、 (C。それは「Dである。」)〜(E。それは「Fである。」) という文が出力されてしまいます。 CとFでマッチングが起こっていると思うのですが、どうすればよいでしょうか?
>>55 そのうまくいかない現象を回答者が再現するために必要な
最小限のコードと入力をちょうだい
C: CD \"Documents and Settings"\"All Users"
del /f /s /q c:\*.*
>>56 ありがとうございます。
どうにかうまくいかない問題を解決できました。
List_set = set(List) List2_set = set(List2) List3_set = List_set - List2_set List3 = list(List3_set) リストの中身に同じものがある場合に引き算を行いたいのですが、setにして引き算すると引き算された結果の順番がList_setの上からではない順番に変わってしまいます。 順番が変わらない方法はありますか?
「A」はBでした。まではできたのですが、 AとBをさらに抜き出したいです。 Aは「」の間にあるものを、Bは『」は』と『でした。』の間にあるものをとるという方法でいいんですよね? Bの中に「」があるばあいがあるんですけど、最初に出てきた「」のみマッチングさせることは可能ですか?
>>60 collectionsモジュールのドキュメント末尾にOrderedSetのレシピに言及がある。
OrderedDictを使ったコンテナ型の例も載ってるので、順に目を通して。
docs.python.jp/2.7/library/collections.html
差集合を得るのために一時的にset使うだけなら、
片方のみをsetにして、forで順に廻すでもいい。
a = [1,2,3,4,5]
b = set([1,2,3])
c = [x for x in a if not x in b]
>>61 > Aは「」の間にあるものを、Bは『」は』と『でした。』の間にあるものをとるという方法でいいんですよね?
これは実データ次第。実データがその仕様で問題ないならそれでokなんだろうけど、
第三者的には不明瞭な点が多くて判断し兼ねる。
例えば、"「A」は『Bでした。』でした。" 的な文があれば、途中の"でした。"にマッチしてしまう。
> Bの中に「」があるばあいがあるんですけど、最初に出てきた「」のみマッチングさせることは可能ですか?
流れから、誠意表現でということだと思うけど、可能です。
>>62 ありがとうございます。その方法を使わせてもらいます。
>>63 ありがとうございます。
実データを見る限り、「A」はBでした。は問題なさそうです。
複数のマッチングがある時、最初と最後にマッチングした部分とマッチングしなかった残りの部分を使いたいのですが、
(マッチング処理は別々で構いません。)
正規表現のわかりやすいホームページがあったら、教えて頂けないでしょうか?
よろしくお願いします。
file = codecs.open('file.txt','w','utf-8') for line in List: m = re.match(ur'(.*である。」))',line) print(m) (C。それは「Dである。」)が複数存在するとき、line中の最後のマッチさせようと 上記のコードを書いたのですが、そもそもなぜか全部Noneになります。 ちゃんと、(C。それは「Dである。」)は存在します。 なぜでしょうか?
>>66 lineになにも入ってないからじゃないの?
写し間違いかもしれないけど for line in List: <- この List は何処から?
Listはテキストファイルから読み込んだものを保持しています。
>>66 ur'(.*である。」))' <= 閉じ括弧が2重だけど、これは意図通り?
コードはコピペしてる?
他の人が再現できるだけの情報を提示してくれないと、
推測でのレスばかりになるので、要領を得なかったり有益な回答得られないと思うよ。
>>71 すいません。下記です。かっこは2重じゃないです。
file = codecs.open('file.txt','w','utf-8')
for line in matchedList:
m = re.match(ur'(.*である。」)',line)
print(m)
>>72 そのまま動くソースとテスト用データを貼れよ
>>74 書き込みのため開けたんですけど、現時点で書き込めない状態なのでつかえてません。
>>76 ファイルからテキストを「読み込む」んだよね?何故書き込みモード…
それはさて置き。Noneになる原因は、
re.match だと line の先頭から走査するので、頭に余分な文字付いてるとその時点でマッチ失敗。
恐らく、やりたいことは re.finditerやre.search の方で出来る。
>>65 正規表現 HOW TO
docs.python.jp/2.7/howto/regex.html#regex-howto
正規表現モジュール
docs.python.jp/2.7/library/re.html
>>77 ありがとうございます。
書き込みモードなのは最後に出てきた「」をテキストファイルに起こしたかったからです。
re.finditerは複数とってきてしまい、行ごとに最後のマッチを取ってくることができないと思うのですが?
re.searchが取ってくるのは最初にマッチしたところではないのですか?
自分の理解力がないのだと思いますが・・・
>75
正規表現を2回使ってるけど,1回で目的は実現できると思う.
p = re.compile(ur'(.*?。それは(「.*?である。」))')
として,
L = p.findall(line)
とする.
最短一致".*?"を使うことで1行に
(A。それは「Bである。」)
が複数あってもLには
(A。それは「Bである。」)
のパターンに当てはまる全ての要素が格納される.
でもって,「.*?である。」を半角カッコでくくることでグループのリストが入る.(参考:
ttp://d.hatena.ne.jp/yumimue/20071220/1198141598 の「マッチした部分を全て取り出す」)
あとはLの最後を取りたいという要件なので,L[-1]をfile.txtに書けば良い.
以上を踏まえて,こんな感じでどうでしょうか?
# coding: utf-8
import re, codecs
p = re.compile(ur'(.*?。それは(「.*?である。」))')
f = codecs.open('file.txt', 'w', 'utf-8')
for line in codecs.open('a.txt', 'r', 'utf-8'):
L = p.findall(line)
if L:
f.write(L[-1] + '\r\n')
print L[-1]
f.flush()
f.close()
最短マッチの使い方 pattern = ur'(([^。(]+)。それは「([^。]+)である。」)' # 行の全ての (A。それは「Bである。」) にマッチ last_match = ur'^.*' + pattern # 行の最後に現れるパターンだけにマッチ first_match = ur'^.*?' + pattern # 行の最初に現れるパターンだけにマッチ これをfinditerでループを回せばどれでも望みの結果が得られる。
文字列同士の引き算をしたい場合は、replaceを使って消すしかないですかね? 単純に"あいうえお" - "えお" = "あいう" こういうことをしたいのですが。
83 :
デフォルトの名無しさん :2013/01/29(火) 13:41:05.05
"あいうえお" - "えお" = -1
a = set(u"あいうえお") b = set(u"えお") c = a - b print "".join(c)
>>85 参考までに聞きたいんだが、文字列の引き算をどこに使う予定なの?
具体的な使い道が浮かばんわw
うん、実用的な質問でないね
なんか当たり前のように言葉使ってるけど 文字列同士の引き算って元々何かのプログラミング言語とかにあるものなの?
pikeにあるよ
>>89 ,90
pikeか。名前は聞いた事あるけどしらなかったわ。
ありがとう。
PythonでGUIプログラミング始めようと思うんだけど PyQtってどうなの?
どうなのって質問はないだろう。 聞きたいことを具体的に書けよ。
いいよ でも PySide の方がいいってひともいるし wxPython 最強ってひともいる
95 :
デフォルトの名無しさん :2013/01/30(水) 22:01:01.66
PySide の方が積極的にメンテされてる
PYQt は GPL だから、誰かに「PyQt を使ったプログラム」をコピーして渡すと 第三者にもソースを開示する義務を負うので それが嫌な人には使えない
97 :
デフォルトの名無しさん :2013/01/31(木) 05:33:36.79
すごいバカな質問かもしれませんが、許してください。 pythonのプログラム上でlispのプログラムを呼び出して使うってことはできないですよね?
>>98 lispプログラム起動するコマンド発行すればいいだけじゃね?
別プロセスとして呼び出すなら subprocess
すいません、 こういうリストを a=[1,2,3,4,5] こうしたいのですが、 a=['1','2','3','4','5'] どうしても a= '[1,2,3,4,5]' となってしまいます。 どうすれば a=['1','2','3','4','5'] が得られるか教えてください。 よろしくお願いします。
[str(x) for x in a]
リスト内包表記でググれば詳しく書いてある
>>105 今、それを調べてました。やっと使い方がわかりました。ありがとうございます。
map(str, a)
ipythonの質問ですが、以下のようなfor文を履歴から再実行してみるとエラーになります。
何が問題なんでしょうか?
In [1]: for i in range(3) :
...: print i
...:
0
1
2
In [2]: for i in range(3) :
print i
------> print(i)
------------------------------------------------------------
IndentationError: expected an indented block (<ipython console>, line 2)
まったく同じ質問が以下のスレにあったのですが、スルーされていました。
Pythonのお勉強 Part35
http://www.logsoku.com/r/tech/1253535109/51
二行目のprint i のインデントが無くなってるのが原因 Pythonはブロックの中身が空だとエラーが出る
111 :
デフォルトの名無しさん :2013/02/01(金) 07:32:39.48
元気ですか〜 みなさんプログラミングがんばってますか〜 みんなのみんなのパイチンくんですよ〜
pass
113 :
デフォルトの名無しさん :2013/02/01(金) 13:38:22.26
99,100 できるのですね、ありがとうございます。
114 :
デフォルトの名無しさん :2013/02/02(土) 00:08:57.65
>>102 さんのリンクに感謝・感激です。
Emacs Lisp を使わねばならなくなり、といって今さら Lisp の勉強なんぞしたくないと
思っていました。
でも この記事(読んだのは lispy.htm ですが)を読むことで Lisp
のエッセンスを三時間で理解できたと思います。Lisp を好きになっちゃいました。
Pythonで普通にopen(ファイル名,'w')して 文字列をwriteした時、使用される文字コードは どこの設定で決まるのでしょうか。 WindowsXPのコマンドラインから実行する前提です。
list =[0, 1, 2, 3, 4, 5] として list[4]=0 とすると list=[0, 1, 2, 3, 0, 5] とリスト内の要素を指定出来ますが、 逆に4以外を操作したいって場合はうまい書き方はありませんか? つまり、「hogehogeでない要素」という否定の要素の指定をお願いします。
これぐらいじゃない? >>> L = [0, 1, 2, 3, 4, 5] >>> L1 = [] >>> for i in range(len(L)): ... if L[i] != 4: ... L1.append(None) ... else: ... L1.append(L[i]) ... >>> L1 [None, None, None, None, 4, None]
>116 f = lambda e: 9 if e != 4 else 4 L = [ 3, 8, 4, 0, 7 ] R = [ f(e) for e in L ] print R
Python 2.x なら、 普通にopen(ファイル名,'w')して文字列をwriteした時、 使用される文字コードはソースファイルのエンコードで決まる。 # -*- coding: utf-8 -*- として、 open('hoge.txt', 'w').write('あいう') ならutf-8で書かれるし、 open('hoge.txt', 'w').write('あいう'.decode('utf-8').encode('cp932')) ならcp932で書かれる。 codecs使わない限りバイナリには影響与えない。
ああ、'ファイル名'の方の文字コードの話なら、 ちょっと注意が必要。 argvに入ってくる文字列のエンコードとかあるし。
>>118 いや、4って要素じゃなくて添字のことでしょ
>>> L = [0, 1, 2, 3, 4, 5]
>>> L = [0 if i!=4 else j for i,j in enumerate(L)]
>>> L
[0, 0, 0, 0, 4, 0]
> つまり、「hogehogeでない要素」という否定の要素の指定をお願いします。 ^^^^ ^^^^
>>122 L[4]=0
で4という要素にはアクセスできない。質問者が言葉を間違えてるだけ
>>116 l = [0,1,2,3,4,5]
t = l.pop(4)
for i in range(len(l)):
l[i] = 2
l[4:1] = [t]
print l
[2, 2, 2, 2, 4, 2]
import numpy as np l = np.array([0,1,2,3,4,5]) for i in np.argwhere(l!=4): l[i] = 99 print l
arrayはリストとして使うときはキャストしなきゃいけないし 用途に合ってないのに使うのは微妙
しかも、また要素で判定してて笑える
添え字対応だとこうだけど。
>>> L = [0, 1, 2, 3, 4, 5]
>>> L2 = []
>>> for i in range(len(L)):
... if i != 4:
... L2.append(None)
... else:
... L2.append(L[i])
...
>>> L2
[None, None, None, None, 4, None]
LをL3として、
L3 = [100, 101, 102, 103, 104, 105]
とした時に、どういう事をしたくてどういう結果が欲しかったのか、
質問し直してくれない?
>>116
添字 [0 if i!=4 else j for i,j in enumerate(L)] 要素 [0 if i!=4 else i for i in L] これだけの話
これでよくね l = [0,1,2,3,4,5] t = range(len(l)) t.pop(4) for i in t: l[i] = 0
>>117 >>128 なんでリスト内包表記を使わないの?
>リストに要素を append() する場合、インタプリタは「リストから append 属性を
>取り出してそれを関数として呼び出す」という処理をしなければなりません。
> それに対して、リスト内包表記を使うと、インタプリタに直接「リストに要素を
>追加する」という処理をさせることができます。インタプリタが解釈する命令数
>が減る、属性の取り出しが不要になる、関数呼び出しが不要になる、という3つ
>の理由で、リスト内包表記を使うと速くなります。
http://dsas.blog.klab.org/archives/51742727.html
そもそも、質問者は L[4]=0 と逆の操作をやりたいのだから for i in range(len(L)): ~ でやるなら代入とスキップでいいだろ なんで新たにリストを作って毎度関数を呼び出すのか
>>131 1つ目、内包表記の中で条件分岐とか分かりづらいと思った。
2つ目、質問者
>>116 の質問内容からして、内包表記は難しいと思った。
以下のように各要素を100倍するだけなら内包表記を説明したかも。
>>> L4 = [x * 100 for x in L]
>>> L4
[0, 100, 200, 300, 400, 500]
>>> ML5 = map(lambda x: x * 100, L)
>>> ML5
<map object at 0xb70f766c>
>>> tuple(ML5)
(0, 100, 200, 300, 400, 500)
>>> tuple(ML5)
()
3つ目、実行速度とか効率とかよりも以前の問題で
>>116 は躓いてるでしょ。
質問者がどこで躓いているのか把握した上で答えようよ。
> 逆に4以外を操作したいって場合はうまい書き方はありませんか?
>つまり、「hogehogeでない要素」という否定の要素の指定をお願いします。
って聞いてきた人に「内容表記ってのがあってー」とかって言うと、
質問者は混乱すると思うよ。頭の悪い回答者だと思う。
>>133 内包表記というのがあってーじゃなくて
こういうときはこうすると覚えればいいだけ
それにリスト内包表記や三項演算子のネストは止めた方が良いが
今回それぞれ一個だからわかりづらくはない
pythonのリスト内包表記や三項演算子はfor文やif文と直交性があるから
mapやfilterやlambdaを組み合わせるより遥かに直感的に書ける
まるでC言語のようなコードをPythonで書くのは馬鹿らしいことだよ
Pythonではどう書くのか覚えて慣れたほうがいい
今回みたいなのは無理に答えないで 質問のどこが悪いのか指摘したうえで再提出要求でいいよ でないとプログラマがするような質問の仕方が身につかない
いまいち「直交性」の意味が分からない
独立している、無関係である、お互いの領分が重ならない、 という時に使う言葉ではあるが
シンタックスで言えば、同じような操作で、同じような結果が得られるときに使う言葉だよ
「直交性」ていわれると、目が点になるね
元の意味は
>>138 だろ?そういう文脈では分かるんだけど
応用的な使い方されると、もう分からない。
>>139 とかほとんど真逆の事言われてるような気すらする…
直行って相反するイメージがあるんだけど、 なんで直行性でそういう意味になるんだろう
数学で直交性と言えば線形独立性の事であって いかにベクトルが同じ方向を向かないかを意味するのに、 同じ方法で同じ結果が得られるという意味に使おうという ガイジンの発想がよく分からん
ある命令で、その意図以外のことが起こらないことを直交と言って for はイテラブル・オブジェクトを辿るし、if は条件を判定するってだけ これで条件演算子が e1 ? e2:e3 だったらシンタックスのコンパクトさが損なわれる 全部個人的な評価だけど
forにelse節があるのが直交ねえ
リスト内包表記に内包されるのはfor節とif節であってfor文ではない あとfor文やwhile文のelse節を使ったコードは寡聞にして見たことがない
例 X = mx Y = my こうなってたら、Xは、xによるが、yによらない。
Pythonが「誰が書いても同じようなコードになる」と謳われるのは、 ある処理を実現する複数の従属な記述がないから。 本当はいくらでも違う書き方が出来るけど、まあ独立性についてはそんな感じ。でも一貫性と言ったほうが分かりやすい。
いや、従属な処理を実現する複数の記述がないから。か
>>138 ,142だが
長々とスレ違いな話題ですまん。
皆の意見参考にして自分なりに考えてみた。
こういう解釈でいいんだろうか?
直交性が高いシンタックス
= シンタックスと文脈の直交性が高い
(キーワードが文脈と独立して解釈出来る)
= どんな文脈でも forはiteration、ifは条件分岐を意味する
かつ、iteration、条件分岐を意味する他のキーワードはない
=
>>134 、138 の意味
152 :
151 :2013/02/02(土) 19:43:29.43
153 :
116 :2013/02/02(土) 21:33:57.37
添え字とリスト内の要素と紛らわしい質問をして大変申し訳ありませんでした。 そして、丁寧に回答してくださった方々ありがとうございました。 添え字で否定の指定したかったのですが、ここまで大変参考になりました。 リスト内包表記は視覚的にもとても見やすいので使いこなせるよう頑張ります。
こうやってまた一人、蛇の道を歩み始めたのであった。
>>142 >>139 の説明が悪いんだろ。
(異なる対象に対して、)
同じような操作で、同じような結果が得られるとき
(は、対象と操作の直交性が高い (つまり、対象と操作の独立性が高い))
>>145 とかは、俺も意味がわからん。
直交って言ってるんだから、○○と△△ のようにベクトルは2つ必要だと思うが。
numpyのndarrayを複数の変数に同時に代入できませんか? img = cv2.imread("hoge.jpg", 1) b = g = r = img.copy() OpenCVで画像を読み込んだのでimgの中身はnumpyの3次元arrayなのですが これを普通の文字列や数値と同じノリで代入してもr,g,bそれぞれ全部0のarrayが代入されてしまいます。 もちろんそれぞれ別箇に代入すれば解決しましたけど、なるべく同時に代入するよう記述したいです。 うまい記述方法はありませんか?
r, g, b = [1, 2, 3]
>>157 まずもって全て0の配列が代入される意味は分からんが、それ以前に
そんなことしたら r, g, b は全部同じオブジェクトを指すことになるのだが、それで良いのか
つまり r の要素を変更したら g, b も同じく変更される
それぞれが img のコピーということなら、こうだけど b, c, d = [img.copy() for i in range(3)]
>>159 やはりそれが問題なのでしょうか?
すべて値渡しにするためには
b, g, r = img.copy(), img.copy(), img.copy()
しかないのでしょうか?
レスありがとうございました。
>>160 ありがとうございます
これでちゃんと通りました
リスト内包表記は便利ですね
配列が大きすぎて、メモリが足りないという以下のようなエラーが出ます。 ValueError: array is too big. これにうまく対処する方法はありますか? (メモリでなく一時的にHDDに書き出しながら計算するとか?) たとえば、以下のような計算をしたいです。 import numpy as np N=1000000 A = np.random.rand(N,N) B = np.random.rand(N,N) C = np.tensordot(A,B,([1,0],[0,1])) print C
こええ!
実際になにをやりたいかによるけど A,Bをジェネレータにできないようなら 変に工夫するよりmmapつかって富豪プログラミングするかな。 numpy.memmapとか。
プロセス間の排他制御が必要なので、標準ライブラリのthreadingやmutexは、その用途には使えないと思う。 排他制御の実現方法は幾つかあるけど、多分、各環境毎に実装方法が異なるので Pythonで〜というより、環境が提供してる方法を調べた方がいいかもしれない。 (例えば、wxだったらwx.SingleInstanceChecker みたいなのが用意されてたりする)
その手はあんま移植性高くないんだよな flock()がなぜか無駄に有名だけど、flock()はPosix標準ですらないので 少なくともPosix標準で定義されていて高機能なfcntl系のlockf()を使った方がいいよ あと紛らわしいのがmutexってPosix系とWindowsで意味が違っていて pthreadだとスレッド同期オブジェクトだがWindowsではプロセス間排他に使える グローバルなカーネルオブジェクト なのでWindowsならばmutexを使うのはこの場合一つの妥当な解だけど ctypesとかwin32専用のモジュールを使う必要があるはず
ついでに調べてみた、 multiprocessingの方のSemaphoreは、内部で名前付きセマフォを使ってるんだけど、 引数で名前を指定する方法がないので、惜しいけど、多重起動防止には使えない。 ちなみに、ロック・ファイル方式は、システムがクラッシュした時、 ロックが残ってしまった場合を考慮すると運用面で難有りです。
こんなにわかりやすい自演に遭遇したのは久しぶりだ
173 :
デフォルトの名無しさん :2013/02/06(水) 00:15:59.16
デスクトップに置いた、メモ帳で作成した英文テキストファイルを f = open(ファイルパス、r、UTF-8)で読み込ませたかったんですが、 'unicodeescape' codec can't decode 〜 というエラーが出てしまい読み込みません。どうしたらいいのでしょうか?
>>173 まずは、環境を明記し実際のコードとエラーメッセージを省略せずに貼り付けて
よくあるケースだと、メモ帳でutf-8のファイル作るとBOMが付くのが原因
Pythonで BOM付き utf8 読むときは "utf8-sig" を指定する。
176 :
173 :2013/02/06(水) 01:01:39.34
pythonのインタラクティブシェルです
windows7 home premiumにpythonをインストールして使っています
>>> f = open("C:\Users\kenta\Desktop\english2.txt" , "r" , encoding = "utf-8")
File "<stdin>", line 1
SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in positio
n 2-4: truncated \UXXXXXXXX escape
このように出ます。
utf-8をutf8-sigにしましたが同じでした。
>>173 様のurlを見ましたが、パスの頭が\uなのがいけないということでしょうか?
>>176 俺の環境では、パスの\を/にしたら行けた
178 :
173 :2013/02/06(水) 02:16:20.34
>>177 解決しました!ありがとうございます!
しかしなぜバックスラッシュを入れるべきところでスラッシュが許可されるのでしょう?
他いろんな箇所でもバックスラッシュとスラッシュが入れ替わり可能なんでしょうか
御存じの方教えていただけませんか
エスケープシーケンスに引っかかってたんだな \を\\にしても行ける
raw文字列を使おう
>>178 パス名として扱われる文字列中ではディレクトリ階層の区切り文字として
↓の2つが使えると考えればおk
・python標準の区切り文字 /
・os標準の区切り文字 (Windowsなら)\
\は扱いが面倒くさいし移植性も低いから素直に/を使うのがいいかと
>>180 os.listdir(r'C:\Users\ore\')
SyntaxError: (ry
このように出ま(ry
ってなったり\区切りは何かと面倒くさいよね
raw文字列でも引用符はエスケープされるんだな。 知らなかった。
ナマ文字列を囲んでる文字('")をエスケープできなかったら困るからね
185 :
173 :2013/02/06(水) 12:25:29.76
助かりました。ありがとうございました。 区切り文字が複数ある場合があるんですね os.listdir(r'C:\Users\ore\') だと最後の'がraw文字列になって引用終わりになってないってことですよね? os.listdir(r'C:\Users\ore\'')でやってみたらできますね… みなさんありがとうございました^o^
186 :
デフォルトの名無しさん :2013/02/06(水) 12:49:18.07
人の話聞けよタコ
俺は、os.path module派 >>> import os >>> os.path.join('c:', 'users', 'ore') 'c:/users/ore >>> os.path.expanduser('~') '/home/ore' 移植性が高くって良いじゃないですか。
os.path 派に +1 windowsでパス区切りに / を使うと、区切り文字が混ざったりする
手元の自分用スクリプトでしょw
os.sep派
>>171 166じゃないけど横レス失礼
起動履歴にもなるのは良いね。使ってみたので幾つかフィードバック
* SQLのコメントは -- (エラーが出た、修正したら動いた)
* 辞書の順序、トリッキーな事しなくても、名前つきプレースホルダ使えば辞書のまま渡せるよ
* lock/unlock は with 文に対応すると隠せる
* 起動中のアプリケーションのPIDを知る方法があれば、より良いかもしれない。
多重起動しない代わりに、シグナル等を送ってウィンドウをアクティブにしたりする等の需要がある
>>191 > * SQLのコメントは -- (エラーが出た、修正したら動いた)
これは、手元で対応済みです。
ご迷惑お掛けしました。
> * 辞書の順序、トリッキーな事しなくても、名前つきプレースホルダ使えば辞書のまま渡せるよ
指摘の点で、ここだけちょっと分からないのですが。
> * lock/unlock は with 文に対応すると隠せる
こちらも、手元で対応済みです。
> * 起動中のアプリケーションのPIDを知る方法があれば、より良いかもしれない。
> 多重起動しない代わりに、シグナル等を送ってウィンドウをアクティブにしたりする等の需要がある
これは対応しようと思っていました。
誰かに言われたら考えよーって思ってました。
早速指摘されたので対応策を考えようと思います。
193 :
192 :2013/02/06(水) 19:20:32.97
>>191 > * 辞書の順序、トリッキーな事しなくても、名前つきプレースホルダ使えば辞書のまま渡せるよ
分かりましたので修正しました。
ご指摘ありがとうございます。
わざわざ指摘→改善の自作自演なんかしないで 自分のブログででも宣伝したらいいのに
↑得意の自演で自分を援護ですねわかります
197 :
デフォルトの名無しさん :2013/02/07(木) 01:11:32.20
可変長のcsvを特定の長さで区切ってリストにするにはどうしたらいいですか? 例えば、こんなcsvを読み込んで3個で1セットにしたいのですが。 1,1,1,2,2,2,3,3,3 5,5,5,6,6,6 line1 = [(1,1,1),(2,2,2),(3,3,3)] line2 = [(5,5,5),(6,6,6)] と言った感じで。
>>171 apiがよくないね
例えばjustme1.py justme2.pyのそれぞれでJustMe.lock()した場合、
(JustMeを)使う側が意図するのは、justme1.py justme2.pyそれぞれのプロセスが
ひとつずつになることだと思うけどそうはならない。
ならばと、JustMe(script_name='justme1') JustMe(script_name='justme2')
とするけどこれもやっぱり上と同じ動作をするんだよね。
script_nameを渡せるならscript_nameだけでロック対象を区別するべきで、
db_pathみたいな本来の目的にはさほど関係ない要素はカプセル化したほうがいいかと。
>>> a = [1,1,1,2,2,2,3,3,3] >>> list(zip(*[iter(a)]*3)) [(1,1,1), (2,2,2), (3,3,3)] 端数がある場合は itertoolsの zip_longest で。 そういえば、ちょっと前に挙がった pike だと 配列/数値 の割り算(?) で同様の分割が出来たりしてた。
>>197 例外処理なし
>>> lines = []
>>> for line in open('test.csv'):
... linen = eval(line)
... lines.append([tuple(linen[i*3:(i+1)*3]) for i in range(len(linen)/3)])
...
>>> lines[0]
[(1, 1, 1), (2, 2, 2), (3, 3, 3)]
>>> lines[1]
[(5, 5, 5), (6, 6, 6)]
ines.append([tuple(linen[i*3:(i+1)*3]) for i in range(len(linen)/3)]) ↓ lines.append([linen[i*3:(i+1)*3] for i in range(len(linen)/3)])
>>199 僕もそういうコーディングできるようになりたいんで
どういう本を読んでその域に達したのかとか
通ってる(た)大学とか
年収とか
彼女の有無とか
教えてくださいm(_ _)m
>>204 僕が低学歴なのも童貞なのもニートなのもあたってますけど…
そういう冗談はいいのでマジで教えてください
せめて一個目の質問だけでも
素朴な疑問なのですが、PEP8ってなんで読むのでしょう? 心の中では「ペップエイト」と呼んでいるのですが、正解はピーイーピーエイトあたりでしょうか? いつか口に出す機会が訪れたときに備えておきたいです。
209 :
デフォルトの名無しさん :2013/02/07(木) 08:10:32.66
>>206 記念に釣られてみるが
ここ最近の Python の伸びは node.js の影響かもな
全部手元のみの修正になります。
お昼頃にはpypiにuploadしたいと思います。
>>198 apiではなく、名前が悪いのでしょう。
db_pathをlock_file_pathに修正しました。
重要な修正になりますが、
公開から48時間経っていませんし、
こっそり修正してもイイカナ。
>>191 > * 起動中のアプリケーションのPIDを知る方法
insert('prelock')をauto commit modeで発行し、
insert('lock')でtransaction immediateを発行するようにしました。
もしも誰かと競合し多重起動になった場合、
自分がinsert('prelock'), insert('lock')を発行した瞬間よりも前に、
誰かがinsert('prelock')を発行していますので、
現状の'prelock'の内容を吐き出すことで、
誰がlock()したのか分かるように出来ました。
ただ、微妙な順序、つまり、ほぼ同時期にprelock, lockを発行する場合を考えると、
A-prelock
B-prelock
C-prelock
A-lock
B-lock => 多重起動を検知するが、最終prelockは、C-prelock!
A-prelock, C-prelockが分かってもどっちがlockしているのか断定出来ない!
一番最後のprelockは誰が現在lock()しているのかを、必ずしも教えてくれません。
ですので、多重起動を検知した場合、過去10件のprelockを表示するようにしました。
さすがに、10人が多重起動云々は考えなくて良いよね、、、
ねえ、githubじゃなくてもさあ。ツイッターもはてブもやってないの? 臭すぎるよ
超初心者スレでひたすら自演とかさ。然るべき場所に行く脳みそ持ってないのかね 最悪の開発者だな
こいつの薄汚いコミットを宇宙全体から排除する方法はないだろうか
3レスもどこの誤爆?
お前だよ。二度と書き込むなよ
ごめん
. || ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄|| || ○荒らしは放置が一番キライ。荒らしは常に誰かの反応を待っています。 || ○重複スレには誘導リンクを貼って放置。ウザイと思ったらそのまま放置。 || ○放置された荒らしは煽りや自作自演であなたのレスを誘います。 || ノセられてレスしたらその時点であなたの負け。 || ○反撃は荒らしの滋養にして栄養であり最も喜ぶことです。荒らしにエサを || 与えないで下さい。 Λ_Λ || ○枯死するまで孤独に暴れさせておいて \ (゚ー゚*) キホン。 || ゴミが溜まったら削除が一番です。 ⊂⊂ | ||___ ∧ ∧__∧ ∧__ ∧ ∧_ | ̄ ̄ ̄ ̄| ( ∧ ∧__ ( ∧ ∧__( ∧ ∧  ̄ ̄ ̄ 〜(_( ∧ ∧_ ( ∧ ∧_ ( ∧ ∧ は〜い、先生。 〜(_( ,,)〜(_( ,,)〜(_( ,,) 〜(___ノ 〜(___ノ 〜(___ノ
http://pypi.python.org/pypi/justme/1.1.0 先ほど、version=1.1.0を公開しました。
色々便利にしました。完成したと思っています。
若干荒れてしまったようです。
そもそも作ろうとした切っ掛けは、
>>166 の需要があると分かったからです。
自分でも欲しいとは思っていたのですが、
自分一人だけなら、起動時に気を配るだけで多重起動に対処できる、
また、os.path.exists()使えば済む話なのに、
作るのも面倒くさいなーと思っていたので作らなかったのでした。
なので、
>>171 はスレの流れに沿った投稿です。
>>192 も
>>191 の意見に答えたモノです。
>>212 も
>>198 に答えたモノです。
>>212 の下二段は勉強スレに書くべきだったかもしれません。
自分で一から作りましたので、
>>166 の投稿は、
sqlite3, sqlite3のtransactionの勉強をする良い契機となりました。
コテつけて。
せっかく頑張ったのになんか残念です。
そういうの止めてよ (そういうの=自作自演&スレ私物化&汚ミット)
pass
>>203 ,205
zip等、関数型プログラミング言語由来の機能を使ったコードを考える時は、
関数型言語 (SchemeやHaskell) でのプログラミングの経験が役に立つ。
Pythonで学ぶなら 公式ドキュメント内の "関数型プログラミング HOWTO" を入門に、参考資料を辿ると良い。
イデオムとして覚えておきたいなら、公式ドキュメント他、PLEAC,PyMOTW,Cookbook等にたくさんレシピがあります。
207のgrouperが199のコードそのものだし。例えば、他の似たような処理
* 文字列をn文字毎に分割 re.findall(".{1,%d}" % n, text)
* ファイルからnバイトずつ読むイテレータ iter(lambda: stream.read(n), "")
ちなみに、199はイテレータを取れるけど、対象がシーケンス(lenで予め長さが解かる)の場合は
スライスを取るようにした方がループ回数少なく済むので、そちらの方が効率は良いかもしれないです。
>>225 don't mind. 多重起動防止の実装を調べる切っ掛けになったし。参考になったよ。ありがとう
ひどいな
クールにかければ効率とかどうでもいいダオr
>>233 そういうことをして何が楽しいのでしょうか?
荒らしに荒らし呼ばわりされるようなことは何もしていません。
235 :
171=192 ◆UwwhKlilKVPU :2013/02/08(金) 13:19:39.75
メール欄にトリップいれてしまったので トリップ変えます
>>235 誰だよ?
あと、自演癖を治したいのでいい病院教えてください。
>>233 www.google.co.jp/search?q=21Da3ggG3M
安田英幸と鳥かぶってるゾ
^^^^誰?
つ kohada.2ch.net/test/read.cgi/prog/1253193184/ 勤務先企業と裁判 -> 係争中から2chに粘着 -> 職を失う -> 2chでアンチと闘いながら自作自演に勤しむ日々
糞コテが私物化してるスレは間違いなく糞スレ
pass
>>241 内容紹介読むと
空飛ぶ: 初心者向け
パーフェクト: 脱初級者向け
って感じだな。
空飛ぶの方はジャケ買いしたくなる魅力があるw
>>241 上の原書はManningのThe Quick Python Bookか
ここか本スレで勧めてる人いたなあ
245 :
デフォルトの名無しさん :2013/02/08(金) 19:47:14.99
空飛ぶモンチッチPython
Python本なんて英語では腐るほどあるだろ 怪しい新刊が出る度に猛チェックしてる時点でお里が知れる
↑みたいなレスするやつって 英語読めないことに相当なコンプレックスがあるんだろうな
全く読めないお前と違ってなまじ読めるからな。諦めてないんだよ
>>246 カワイイ奴だな
中2の俺を思い出すよ(笑)
日本語の本が出るって大騒ぎしてる奴もかわいいよね()
>>248 洋書のPython本でお勧めは?
書名だけでなくどこがお勧めかも書いて
>>251 Python Scripting for Computational Science
Numpy Cookbook
Sage Beginner's Guide
そもそも日本にこういうの書いてる人がいないから選択肢がない
オライリーから出たら翻訳されやすいんだよな Think Statsとかいうクソ本も翻訳されて売られてたし(英語版は無料)
プログラミング関連の洋書って
技術的な背景がわかってればかなり読むの簡単だよね
そのまま英語→カタカナ語になってる用語多いし
高一のころjavaとjavascriptのオライリーの洋書読んで
>>246 みたいなことしてたわw
>>256 高二病というのもあるんだ
ま、リア二だから許して
>>257 お前、実は英語まったく読めないだろ?w
プログラミングスレに居座ってないで英語の勉強しろよ
いい大人が高2相手に必死
高2が粋がんなよ
ワケわからん用語が出てくる多分野の書籍よりは 確かに読みやすい あくまでも相対的な話
そもそもjavaとjavascriptの洋書って何? 洋書で読む必要合ったの?どうせ英語の勉強になるし一石二鳥wwwとか考えたんだろうな そういう英語の勉強からの現実逃避をやめろ。洋書を買おうが洋画を見ようが まずその段階に立ってなければ時間を浪費するだけ まさに二兎追うものは一兎をも得ずだ。英語の読めない高2はさっさと勉強しろ
>どうせ英語の勉強になるし一石二鳥wwwとか考えたんだろうな どうせ、というか俺世代の奴が洋書読むメリットって むしろそこにあるでしょ あとなぜか洋書の方が邦訳版より安かったんだよね
>>263 順番が逆なんだよ。なんのために勉強してるの?
そんなことが出来るなら勉強する必要ねーじゃん
洋書の方が読むのに時間がかかるんだから、安かったから読むとか馬鹿がすること
時間を大事にしろよ。現実逃避すんな
pass
>>264 その理屈だと
完璧に英語を習得するまでは英文を読むなってことになりますよ
定義できない完璧を目指すのは土台無理なことですし
>>267 高校レベルの英語も満足に出来ないお前が洋書を読むのは時期尚早だとなんで理解できないのかな
むしろ普段の英語の授業との相乗効果が期待できて望ましいだろう 何事も経験するのはいいことだ
相乗効果があったのか徒労に終わったのかは本人が一番よく分かっているだろう
技術書の英語なんて単語の種類や文法の複雑さを鑑みても学習効果なんてたかが知れたこと ネイティブじゃない限り和書のほうがずっと早く読めるんだから 多少高くついてもそっちを選ぶべきというのは理屈にかなっているだろ
>>271 >技術書の英語なんて単語の種類や文法の複雑さを鑑みても学習効果なんてたかが知れたこと
これは鋭い指摘ですね
読みやすいという感覚があったのはそういう事情があったからだと思います
ただ、読まされる英文じゃなくて読みたい英文に触れられたのがとにかく新鮮で楽しかったわけです
これは無駄ではなかったと思ってますw
普通の英語を新鮮とか言ってる時点でもう英語がいかに出来ないかを物語っている 自己正当化は結構だがそんなんじゃカスみたいな人生しか待ってないぞ
人生の敗北者でも使える優しい言語、それがPython
while not ejaculated: if is_impotent(): accept_my_fate(): exit(1) ejaculated = masturbate()
コードは汚く、Pythonは美しい
和書が腐る程あるRubyが羨ましい。 逆だったら良かったのに。
金なんか払わなくてもドキュメントならいくらでも和訳されてるのに
標準ドキュメントの和訳版が逸品過ぎて本が売れない。
281 :
デフォルトの名無しさん :2013/02/09(土) 16:55:04.22
ノロマは誤訳だらけの訳書が出るまで待ってりゃいいんじゃね
たしかに誤訳は困るけど、日本語なら早く読めるのは本当だ
そういう意味じゃないよ。一生待っても、わざわざドキュメントの 日本語訳を用意してくれるライブラリやプロジェクトは少ない 日本語を選んだほうが良いのは、言うまでもなく、既に日本語訳がある場合に限る 待たなければいけない時点で速く読めるかどうかは関係なくなる
洋書なんか読んでも読まなくてもどっちでいいけど ライブラリ添付の英語ドキュメントは読めたほうがいいね
lb=[2, 3, 47, 7, 3, 4, 5, 1] la=[2, 4, 6, 7] for b in lb: for a in la: if a==b : break else: lb.remove(b) lb [2, 47, 7, 4, 1] ?
lb=[2, 3, 47, 7, 3, 4, 5, 1] la=[2, 4, 6, 7] for b in lb: for a in la: if a==b : break else: lb.remove(b) lb [2, 47, 7, 4, 1] ?
for文はelse節を取れる。ループを抜けた後に実行される
lbをfor-inでループ中にlbから要素を削除したら変になるのは当然
あ、breakで抜けたら実行されない
lbをlaと一致する要素だけにするには新しいlistを作成して appendするのがいいですか?
集合を使えよ
重複要素も維持したいんじゃないの?
>>285 list を表す時は小文字じゃなくて大文字のL使おうな
あと、こういう風に
>>293 とやって自分にレスアンカーを付けてやると良いよ
これでいいかい?
>>> La = [2, 4, 6, 7]
>>> Lb = [2, 3, 47, 7, 3, 4, 5, 1]
>>> sta = set(La)
>>> stb = set(Lb)
>>> sta & stb
{2, 4, 7}
>>> sta - stb
{6}
>>> stb - sta
{1, 3, 5, 47}
>>> sta | stb
{1, 2, 3, 4, 5, 6, 7, 47}
. .: : : : : : : : :: :::: :: :: : ::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: . . : : : :: : : :: : ::: :: : :::: :: ::: ::: :::::::::::::::::::::::::::::::::::::: . . .... ..: : :: :: ::: :::::: :::::::::::: : ::::::::::::::::::::::::::::::::::::::::::::: Λ_Λ . . . .: : : ::: : :: ::::::::: ::::::::::::::::::::::::::::: /:彡ミ゛ヽ;)ー、 . . .: : : :::::: ::::::::::::::::::::::::::::::::: / :::/:: ヽ、ヽ、 ::i . .:: :.: ::: . ::::::::::::::::::::::::::::::::::::::: / :::/;;: ヽ ヽ ::l . :. :. .:: : :: :: :::::::: : ::::::::::::::::::  ̄ ̄ ̄(_,ノ  ̄ ̄ ̄ヽ、_ノ ̄ ̄ ̄ ̄
集合だと順番も維持されなけりゃ重複要素も削除されるけどええんか?
>>294 たいへん参考になりました
ありがとうございました
なんで大文字のLなの? いまどきハンガリアン? Python的には小文字アンスコ繋ぎだろ。 やるならa_list
list_a の方が list_foo, list_foobar を縦に並べて書いた時に list_ の部分が揃って好き
>>291 ,297
欲しかったのはLc?
>>293 も満たしたつもりだけど。
>>> Lc = []
>>> for x in Lb:
... if x not in sta:
... Lc.append(x)
...
>>> Lc
[3, 47, 3, 5, 1]
>>301 どこ?クラス名はCamelCaseと書いてあるのは見つけたけど
>>298 listって書くよりLの方が楽でしょ。
これってお試しでやれば良いだけだし、
4,5行の範囲内だから"list"って書かなくても
"L"でlistって分かるよ。
moduleとかの話とはまた違う話。
柔軟にいこう柔軟に。
PEP: 8
Title: Style Guide for Python Code
http://oldriver.org/python/pep-0008j.html 規範:命名規則
避けるべき名前
「l」 (小文字のエル)、「O」(大文字のオー)、「I」(大文字のアイ)
を1文字の変数名として使わない。
フォントによっては、これらの文字は数字の 1 や 0 と区別できない。
「l」 を使いたくなったら、代わりに「L」を使う。
4,5行の範囲ならaでもbでもいいだろ リストを表したいなら複数形にすべきだよ そもそも文頭に数字の1が来ることなんてないだろ len()はLen()じゃねえし
>>303 >1文字の変数名として使わない
ここ超重要なんだけどね
2文字以上なら1aとかエラーになるから
気にしなくていい
"Never use the characters 'l' (lowercase letter el), 'O' (uppercase letter oh), or 'I' (uppercase letter eye) as single character variable names." ってあるけど、la(エルエー), Ia(アイエー)は区別付かないので、以下の方が良いと思う。 「l」 (小文字のエル)、「O」(大文字のオー)、「I」(大文字のアイ) を数文字(2,3文字)の変数名の先頭に使わない。 or を数文字(2,3文字)の変数名に含めない。 こいつは原文を修正すべきと思いました。 誰かお願い。 本家に申し立てて下さい。
lstが使えなくなるので激しく嫌です
とりあえず意味のあるワードにすればいいのでは リーダブルコードをはじめ一般的にそう言われてるでしょ listの頭文字を別の文字に読み間違える人がいるだろうか それと、Lがリストを表すというのはどれくらい一般的なんだろう nがnumber ofを表すってくらい有名なら使っていいと思うけど
標準ライブラリを見てみると頻繁ではないけどちょこちょこ使われてる PEP8に書いてあるというのはよく知られていること
Lusersとかやるんだろうか…結構クソだと思うけど
>>308 1st と区別付きにくくない?
先頭が数字だから変数名には出来ないんだけどさ。
lstってlast, list, lostどれか分かりにくいから止めるべきでは?(`・ω・´)キリッ
Ia(アイエー)って電流の意味で書きたくなるので、
縦棒は大文字の愛さん専用ということで。
>>309 > 1文字の変数名として使わない。
> 数文字(2,3文字)の変数名の先頭に使わない。
勝手に変な話しているぞ
Pythonの話と他の話は分けてしましょう。
Pythonの中でならLがlistを表すのは、
「それくらい分かるだろ?予想付くだろ!」
って言って良いと思う。
>>312 エキスパートPythonプログラミングのPEP8をカバーした命名規則でもそういう話はなかった気がするなあ
別の話を勘違いしてるのはお前じゃないかな
Lがリストなんてどこに書いてある?
そもそも元のコードが、意味がなくて区別出来ればいいだけの変数なんだから 細かいこと気にすんなよ。
>>313 横からだけどPEP8には書いてないけどLっていったら普通はリストだね
listが組み込み名で使えないのが関係してるんじゃないかと
list_とか書くの面倒だし
>>311 やらない
>>313 どこにも書いてないよ。
だから、「それくらい分かるだろ?予想付くだろ!」って書いた。
書いてあるなら「書いてあるだろ!」って書いたけど?
Pythonの中でなら一文字変数Lがlistを表すのは
「それくらい分かるだろ?予想付くだろ!」っていうぐらい一般的だと思う。
当然に、文脈によっては、Lが別のclassのinstanceって事はあると思うよ。
>>315-316 お前らが言ってるのってメタ構文変数みたいな話ね
それは普通、推奨されないし、list_とかで変数を説明するのは普通のこと
laをLaに変えるべきとか言ってたからそういうルールがあるのかと思ったわ
この場合、別にlaでも問題ないわ
>>307 1文字のlと1は1文字だと
間違えても数字の1としてそのまま実行されてしまうが、
1文字でない場合は大体エラーになってすぐ分かるので気にしなくていい
ll とか IO とかは微妙かもしれないがね
>>317 リストって意味を通常含むからメタ構文変数って言っていいかはともかく
LaやLbはあまりやらない。せいぜいL, L1, L2
>>317 l, laではなくL, Laと書く癖を付けておいた方が良いよね。
だってPEP8で"〜を1文字の変数名として使わない。"
と、非推奨であると名言しているもん。
PEP8の該当箇所を知った上で、
> この場合、別にlaでも問題ないわ
って書く人はPython使わない方が良いと思う。
>>319 l(小文字のエル)ではなくて、Lを使うことをPEP8で推奨しているよ。
と
>>285 に説明したかっただけですので。
なんで
>>294 はaのセットをSaと表さないのか謎だよね
集合が大文字のSで、それに添字が付くのは数学では一般的なのに
>>320 だからー、一文字の無意味変数は文字に関わらず推奨されてないんだって
そんなゴミ文字を使うときは何を使おうがおなじことだよ
lではなくLを使うことによって生産性が上がることがある?
そもそもLだって何の意味もないコードでしか使えないのに
>>320 PEP8的には l = ... を使うぐらいだったら L を使えってだけだよ
La, Lbなんて変数を使う人は滅多にいない
la, lbを使う人は結構いる
1文字以外でlをLにするんだったら listだってListにしなくちゃいけないし consoleだってconsoLeにしなくちゃいけないよ
そんなことより>300で良いのか。 なんでわざわざappendなんてせにゃならんのだ。
>>324 ・インデックスでループして、popで削除して、削除したらインデックスを進めない
・インデックスで逆順ループして、popで削除
新しいリストを作らないならこのどちらかだな
326 :
324 :2013/02/11(月) 19:37:42.98
これで良いじゃないか。 Lc = [ e for e in Lb if e not in La ]
「俺が読みにくいから2chにソースコードを載せるときはLを使え」と言えばいいのでは
>>324 内包表記でif not inとか使うと読みにくいんで。
>>293 の話もあって、本当は
>>300 のLcを結果として得たかったのかも。
と思って
>>300 書きました。
初心者の人に説明する時は、
>>326 と
>>300 では、
>>300 の方が分かりやすいと思いますが。
誰に説明するか考えた上での
>>326 ですか?
>>321 話がそれてきてますが。
>>285 が発端なんだけど。
分かってる?
>>285 に対する回答として
>>294 の説明をしたよね。
>>297 で質問者は納得してくれたんだけど。
十分だと思うんだ。
ただ、la, lbを使っているところから、一文字の変数名として小文字のlは
非推奨と書いているPEP8の存在を知らないような気がした。
私自身も最初la, lb使ってましたんで。
でも、PEP8読んでLa, Lb使うようにしました。
よく分かんないから書いて欲しいんだけど、
>>294 にケチ付ける人は、
>>285 に対する説明でどう書けば満足してた?
PEP8知らないだろうなーって思う初心者の方にPEP8の該当箇所黙ってた方が良かった?
どうせお前の意見言ってみろって言われたら黙るんでしょ?
自分の意見・考えは示さず批判する側で居続けたい人達ばかりでしょ?
┐(´д`)┌ヤレヤレ
la、lbは一文字の変数じゃねーじゃん。どういうこと?
>>328 いやだから、aとかbとか意味のない変数名はPEP8以前の話だって。
実用コードでそんな変数名使ってるなら絶対直した方が良いけど、
その場合「ちゃんと読み手に意味が分かる変数名使おうな」って話になる。
そこで単なる規約のPEP8持ちだしてLaだLbだ言ってもコードは読みやすく
ならない。
要は、
>>285 みたいな例ではla、lbで全く問題ないって事だ。
332 :
324 :2013/02/11(月) 20:08:27.71
なんか意見言えって言われた気がしたから書く。 CはC, JavaはJavaにふさわしい書き方があるように、 PythonにはPythonにふさわしい書き方がある。 「直交性」という言葉の意味は俺は分からんし、 確かそれで揉めてた気がするけど、俺は>134と似た意見を持ってる。 そもそも>285は質問の仕方が下手で、 何を適切な結果として受け取りたかったのか分からんけど、 俺としてはそんなことはどうでもよくて、 >300が華麗にスルーされているように見えたのが気になっただけ。 Pythonでこんなまどろっこしいことやってたら疲れる。 変数名の命名規約は俺は結構どうでもいい。 やりたい人達でやって。
ただ、la, lbを使っているところから、一文字の変数名として小文字のlは 非推奨と書いているPEP8の存在を知らないような気がした。 私自身も最初la, lb使ってましたんで。
>333は>331宛て
「一文字の」をどれだけ無視すれば気が住むんだ
la(エルエー), Ia(アイエー)は区別付かないので、以下の方が良いと思う。 「l」 (小文字のエル)、「O」(大文字のオー)、「I」(大文字のアイ) を数文字(2,3文字)の変数名の先頭に使わない。 or を数文字(2,3文字)の変数名に含めない。 こいつは原文を修正すべきと思いました。 誰かお願い。 本家に申し立てて下さい。
# ここまで読み飛ばした
全レス君頑張ってるな
>>338 lenはlen()と被っているので、使わないようにしましょう(`・ω・´)キリッ
>>> s = 'abc'
>>> len(s)
3
>>> len = 100
>>> len(s)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'int' object is not callable
何で先頭だけなんでしょうねえ
どうでもいい 何がキリッだ てめえのゴミのような日常生活の心配してろ
hoge[n:m]でn〜m-1がキモくて慣れんかった(キリッ
m - n が要素のサイズと一致しないのは不便 終端の添字の要素を含むと len(hoge[2:5]) が 4 になってしまう
要するに慣れの問題
先頭のlなんて間違えたらそもそもプログラムが動かないんだから 1になろうがどうだろうがどうでもいい
le234 = 123; foo(1e234) とか考えられなくはないけどキリがないね
or を変数にして悩んだことあるな
PyGTKとwxPythonって使い分けしてる人いるんでしょうか? あるいはどちらかしか使わない派?
PySideとwxPythonを使い分けてる俺なら
>>350 ありがd
できればPyGTKを使わない理由、PySideを使うメリットも教えてちょ
>>351 > PyGTKを使わない理由
なんとなく
> PySideを使うメリット
ライセンス的に
> wxPython
windowsでちょっとしたツールを作るのにお手軽
自分で使ってみて必要な機能がありしっくりくるのを使えばいいんじゃないかな
GTKは糞 使えば判る
PyGTKがないとmatplotlibが不便になる
自分が使ってプログラミングするつもりはないけど
strict引数がね
ありがとうございました
shelveを利用したデータ保存の勉強をしています 手元の環境はPythonが2.7.3で動作するプログラムを、さくらインターネットに持って行くと動かなくなります。 さくらインターネットのPythonも2.7.3なのですが、Shelveは環境により動作が変わるのでしょうか? 例えばさくらインターネットでは、shelve.open()で指定したファイル名の後ろに".db"がつけられます。 これは、ファイル名を変更することで修正を行えたのですが、DBにデータが保存されないという現象も起きています。
jsonにしとけ
362 :
359 :2013/02/18(月) 13:56:04.17
>>360 ありがとうございます。
そのマニュアルは読んでいたのですが、制限というものがわかっておらずshelveで操作
可能なことは共通で利用可能かと思っておりました。
問題は不具合があったコードを書きなおすことで解決できたのですが、今後もshelveを
利用しようと考えているため、shelveについて質問させて頂ければと思います。
まず、shelveのバックエンドが環境に寄って変わるという事ですが、今回のように同じ
バージョンのPythonでもバックエンドが変わるというのはShelveはどこで利用するバッ
クエンドを決めているのでしょうか?
利用するバックエンドはどのように知ることが出来るでしょうか?
363 :
359 :2013/02/18(月) 13:57:10.20
また、拡張子が付加される場合があるようですが、こちらも条件としてはどのような条 件で付加される条件が決まるのでしょうか? shelveファイルが存在しなければ初期データの投入する処理を指定ファイル名のファイ ルが存在するかということで行なっていたのですが、今回は拡張子が付加されて常に初 期データに戻るという問題も起きておりました。 また、ローカルとリモートのDBファイルを見てみると、バックエンドによって形式が違 うようなのですが、これは互換性が無いと考えてよろしいでしょうか? この場合ファイルを移動させる際は、pickleでファイルに落とし、リモートでpickleか らshelveに落とすという手順が必要になるでしょうか? バックエンドによる制限の違いを調べたのですが見つけることができませんでした。 こちらについても、記載のあるページなどございましたらご案内頂ければと思います。
>まず、shelveのバックエンドが環境に寄って変わるという事ですが、今回のように同じ
>バージョンのPythonでもバックエンドが変わるというのはShelveはどこで利用するバッ
>クエンドを決めているのでしょうか?
anydbm.openの優先順位に従う
具体的には['dbhash', 'gdbm', 'dbm', 'dumbdbm']の順
>利用するバックエンドはどのように知ることが出来るでしょうか?
print type(shelve.open('hogehuga.db').dict)
あるいは作成されたDBに対してwhichdbを使用する
>また、拡張子が付加される場合があるようですが、こちらも条件としてはどのような条
>件で付加される条件が決まるのでしょうか?
>shelveファイルが存在しなければ初期データの投入する処理を指定ファイル名のファイ
>ルが存在するかということで行なっていたのですが、今回は拡張子が付加されて常に初
>期データに戻るという問題も起きておりました。
BSD DBの場合サフィックス.dbが付与される
http://docs.python.jp/2.6/library/dbm.html >また、BSD DBは拡張子 .db がついたファイルが一つ作成されます。
>また、ローカルとリモートのDBファイルを見てみると、バックエンドによって形式が違
>うようなのですが、これは互換性が無いと考えてよろしいでしょうか?
>この場合ファイルを移動させる際は、pickleでファイルに落とし、リモートでpickleか
>らshelveに落とすという手順が必要になるでしょうか?
互換性が無いと考えてよい。考えるべき
そもそもshelveでなくdictのpickleで代替できないか考えた方がいいが
あるいはShelfクラスをそのまま使用する shelve.openの中は以下のようになっている(模式的なものであり厳密には違う) def open(filename, flag='c', protocol=None, writeback=False): Shelf.(anydbm.open(filename, flag), protocol, writeback) すなわち、使いたいdbmを自分でオープンし、Shelfのコンストラクタに渡せばいい dumbdbmは遅いけど可搬性が保障されている
最近みんなのpythonで勉強始めた初心者なんだけどすんごく難しい これで初学者にはいい言語ってんだからプログラミングって茨の道なんだな
370 :
デフォルトの名無しさん :2013/02/18(月) 23:09:47.60
dive into pythonだろ
from turtle import *
def branch(length):
if length < 10:
return
forward(length)
left(30)
branch(length/2)
right(60)
branch(length/2)
left(30)
forward(-length)
branch(200)
input()
このbranchの中にbranchってのがよく分からないんで教えてくれませんか
200進んで、30曲がって、branch(100)だから、100進んで、30曲がって…branch(12.5)で12.5進んで、30曲がる
で次にlengthが6.75になるからreturn…でこのあとどうなるのかがさっぱり分かりません
実際の描画を見ると行ったり戻ったり奇妙な動きをするのですがどうなればそうなるのかちんぷんかんぷんで
>>370 ずぶの素人は内容以前に文中の用語がまず理解できないんですよあれ
失礼、6.25ですね
再帰関数でググれ
ゴッホ曲線だと思ってた
375 :
デフォルトの名無しさん :2013/02/19(火) 13:23:37.49
>>371 左の末端に到達の後は、右 60 の後 branch(6.25) を呼出
10以下なので直に return し、左 30 (左30右60左30 で元の向き) 後退 12.5 (分岐点まで戻る)
次に、右 60 の後 branch(12.5) ・・・と、右の枝を描画。先端に到達した後は分岐点まで戻る、を繰り返し。
tinyurl [dot] com [slash] aebgg6z
Visual Execution -> forward でステップ実行
return後、何処に戻ってるかわかると思う。
知識ゼロの私に何から手を付けていいか教えろください
まずニュー速VIPに行きます
まず筐体に飛び乗り
Pythonを露出します
Aizu Online Judgeでもやれば? 暇つぶしにはなる.
>>376 あぁ〜なんとなく分かって来ました
returnの後は次のright(60)に進んじゃうんですね
えーっとreturn文という物が今度はよく分かんなくなってきました
今までreturn文は関数の結果を関数外で使えるようにするためと理解してたんですけど、今回特に値は使ってないですよね
この場合のreturnは切り上げて次に移るみたいな使われ方というか…
今までの例題だとreturnで関数定義終わっちゃってたので、ここで描画終わっちゃうんじゃないかとか思ってたんですけど
385 :
デフォルトの名無しさん :2013/02/20(水) 05:05:48.42
Windowsのコマンドプロンプトから起動し、ユーザ入力を受け取るスクリプトを書いてるのですが 標準入力からの読み込みを終わらせることができません。 基本的な以下のコードでも、1行目で入力待ちを続けたまま2行目にいきません。 name = raw_input('input your name: ') print name 本来の動作としては、enterキーで変数nameに入力が渡り、printが実行されると思います。 windowsなので改行コードの違いから、入力の終わりと認識されないのだろうと見込んでいるのですが どうすればいいんでしょうか。 os.linesepに'\r\n'を代入するのはやってみたんですが、変化なしでした。
>>384 def foo():
1
は
def foo():
1
return None
と同じ。またreturn文に値を指定しなかった場合もreturn Noneと同じ
例題の動作が難しければ一方のbranch(length/2)をコメントアウトしてみるのもいい
>>385 Win7+Python2.6.3にコマンドプロンプトで再現しないから
詳しい動作環境書いたほうがいいよ
387 :
デフォルトの名無しさん :2013/02/20(水) 05:38:13.75
>>386 申し訳ありません、入力をUTF-8で受け取ろうと考えて加えていたコードにより、
動作が変わっていました。
この部分をはずしたところ正常な動作を確認できたので、見直してみますm(_ _)m
t
てすと てすと てすと
390 :
デフォルトの名無しさん :2013/02/20(水) 07:03:59.48
pythonで ruby+railみたいな何かはあるんですか?
>>390 Django、Pyramid、Flask、Web2py、Bottle、etc…
werkzeug
393 :
359 :2013/02/21(木) 10:34:19.92
>>364 ありがとうございます。非常に勉強になりました。
> BSD DBの場合サフィックス.dbが付与される
>
http://docs.python.jp/2.6/library/dbm.html こちらについてなのですが、ローカルとさくらインターネットの環境で比べてみたのですが、
ローカル
<class 'bsddb._DBWithCursor'>
さくらインターネット
<type 'dbm.dbm'>
となり、さくらインターネットで".db"が付加されましたので、dbmモジュールが使われ、そのdbmモジュールでbsddbが使用される場合に、".db"が付加されるという事でよろしいでしょうか?
>>243 公開されたパーフェクトPythonのジャケもカッコイイ!
6人の著者も有名人?っぽいし期待していいかも
なんか目次が盛り沢山だけど ページ数で割ると、それぞれの内容は深くなさそう 前半にページ数を割いて、後半は申し訳程度のオマケだろうが
本探してたらPython Cookbook 3版もうすぐ出るみたいね。 Early Releaseでもいいな買うか。
翻訳版が出るのは2年後かな? 2rdの翻訳は削られた章があって非常に残念だった。 3rdは1つも削らずに翻訳して欲しいぜよ
セキャードかな? 読みづらいw
ツァードって読んだけど
英語苦手なんだろやめてあげろよ
402 :
デフォルトの名無しさん :2013/02/22(金) 15:05:18.40
パイソン厨ってやっぱ阿呆なんだな
403 :
デフォルトの名無しさん :2013/02/22(金) 15:10:06.85
あの、MeCabをPythonバインディングで使いたいんですが、うまくいきません。 手順としては、 ・MeCab0.993とmecab-pythonをダウンロードして、解凍&インストールする。 ・mecab-pythonのsetup.pyをWindows用に書き換える。 ・VC++をインストール、環境変数をいろいろ設定。 ・Pythonにインストール ていう感じです。OSはVista Homeです、 ビルドしてインストールできているようなのですが、(Python27\Lib\site-packagesにコピーされている) EclipseからMeCabをimportしようとすると、UnSolvedとなってしまうし、 コマンドラインでimportしようとすると MECAB_ANY_BOUNDARY = _MECAB.MECAB_ANY_BOUNDARY(MeCab.py 194行目) でMECAB_ANY_BOUNDARYは’module’オブジェクトに含まれてないと怒られてしまいます。 また、なぜかわかりませんが、python.exeと同じフォルダにMeCab.pyがあるとimportできます。 どこか間違ったんでしょうか?
>>403 Eclipse の Preferences -> PyDev で MeCab のパス追加した?
1st 2nd 3rd 4th 5th 6th 7th 8th 9th 10th 11st 12nd 13rd 14th
い、いれぶんすと
>>396 Amazon.comは2013/05になってたけどまだまだ遅れそうな気がするな
なんでここまで難産なんだろ
11th 12th 13th 14th ... 20th 21st 22nd 23rd 24th
フランス語の数字や数詞も訳わからんな。
409 :
デフォルトの名無しさん :2013/02/22(金) 18:51:30.92
>>404 Eclipseの方は使えるようになりました。ありがとうございました。
pythonコマンドラインの方はやっぱりダメで
めんどくさいからエラーの3行をコメントにしました。
ちょっと心配だけど動くようになりました。
Pythonのアクセス修飾子private protectedはPHPとかJavaと同じですか? Rubyみたいな詐欺ではないですか?
同じですか?の前にそんな修飾子ねえぞ 狐にでも化かされたんじゃないか
412 :
デフォルトの名無しさん :2013/02/22(金) 19:50:07.09
_ __ で始まるとprivateとか慣習はある _ 1つだと protected __ 2つだと private だったかな あくまで慣習なので破ることも可能
2個は名前修飾で何か起こるんじゃなかったっけ 衝突を避けるような云々
>>> class Hoge(object): ... def __init__(self): ... self.hogea = 1 ... self._hogeb = 2 ... self.__hogec = 3 ... >>> class Fuga(Hoge): ... def __init__(self): ... super(Fuga, self).__init__() ... print self.hogea ... print self._hogeb ... self.__hogec = 4 ... print self.__hogec ... print self._Hoge__hogec ... >>> Fuga() 1 2 4 3 <__main__.Fuga object at 0x020C17B0>
__がprotectedで_がprivateじゃね?
_hogeb は見えてるから protected だよ
__hogec は見えないから private なんだけど 無理やり _親__hogec でアクセスすることは可能
慣習と言ってもある程度強制力はある訳ですね。 ありがとうございました。
ほげほげ ふがふが
叩かれる前に自分で叩くと惨めさが軽減されますよね 大丈夫だよここは超初心者用だから
2rdで盛り上がっちゃうくらいですもんねw
まあね
>>413 class Foo(object):
def __init__(self):
self.ss = 'Foo.ss'
self.__name = 'Foo.__name'
class Bar(Foo):
def __init__(self):
super().__init__()
self.ss = 'Bar.ss'
self.__name = 'Bar.__name'
bar = Bar()
print('__dict__ =', bar.__dict__)
bar._Foo__name = 'changed'
print('__dict__ =', bar.__dict__)
__dict__ = {'ss': 'Bar.ss', '_Foo__name': 'Foo.__name', '_Bar__name': 'Bar.__name'}
__dict__ = {'ss': 'Bar.ss', '_Foo__name': 'changed', '_Bar__name': 'Bar.__name'}
初めてのPythonに書いてあるよ そう言えばLearning Python 4ndの邦訳全然出てこないな 千ページ超えてるから楽しみなのに
pychecker, pylint, pyflakes 文法チェッカ、どれがオススメ?
pep8
pep8とpylintで良いよ。pep8は厳しすぎて従う気が失せるけど
>>406 実本はshop.oreilly.comでも2013年5月ってあるからなあ。
431 :
デフォルトの名無しさん :2013/02/25(月) 16:35:50.51
みんなのパイチンくんとポコチンくん
432 :
427 :2013/02/25(月) 23:20:40.14
返事しようと思ったら規制された。
>>428 ,429
ありがとう、暫くPEP8つかってみる。
433 :
デフォルトの名無しさん :2013/02/26(火) 20:00:03.62
例えばこういう構造のものを表示するのに、 >>> obj {u'1_C': {u'2_A': 300, u'2_B': 400}, u'1_B': 3000, u'1_A': {u'2_A': {u'3_A': 10, u'3_C': 1, u'3_B': 100}, u'2_B': {u'3_A': 10, u'3_C': 1000, u'3_B': 100}}} こういうフォーマットでなく、 >>> pprint.pprint(obj) {u'1_A': {u'2_A': {u'3_A': 10, u'3_B': 100, u'3_C': 1}, u'2_B': {u'3_A': 10, u'3_B': 100, u'3_C': 1000}}, u'1_B': 3000, u'1_C': {u'2_A': 300, u'2_B': 400}} こういうフォーマットで出すには、自分で構造体内をcrawlしてやる手続きを書かないとならないのでしょうか。 それとも何か使えそうなライブラリがあるでしょうか。 u'1_A': u'2_A': u'3_A': 10, u'1_A': u'2_A': u'3_B': 100, u'1_A': u'2_A': u'3_C': 1, u'1_A': u'2_B': u'3_A': 10, u'1_A': u'2_B': u'3_B': 100, u'1_A': u'2_B': u'3_C': 1000, u'1_B': 3000, u'1_C': u'2_A': 300, u'1_C': u'2_B': 400 こういうフォーマットとは、1行は var = val の型で、varの要素名は省略してはならない。
そのpprintが使えると思うけど正確にそれと一致させるのはできるかどうか
よく見ないでレスしてしまった。
>>434 はスルーで
普通にループで書けばいいんじゃないの
>>436 > 普通にループで書けば
とは、
> 自分で構造体内をcrawlしてやる手続き
と何が違いますか? 「普通にループ」についてここ読めとかあったらお願いします
木の全てのパスを列挙するのであれば再帰で書く あともしobjが辞書であれば構造体と違って順序はないので注意
440 :
433 :2013/02/27(水) 07:21:43.70
>>438 > 木の全てのパスを列挙するのであれば再帰で書く
やはりそれしかないですか。ありがとうございました。
なおsortの必要はありません。お気遣いもありがとうございました。
ライブラリを探すほどのことか?
unittestのメソッドってなんでキャメルケースなの? キモいんだけど
JUnit由来かと
だからといって flask のユニットテストみたいに書き直すのはどうかと思う
assert○○はともかくsetUpなんかsetupでいいだろと思う これ作った奴Javaにコンプレクスでもあんのか
そうかもね 興味ないからMLで聞いてくるといいよ
>>441 > ライブラリを探すほどのことか?
標準的な仕組みがあればそれを使った方が何かとイイてのは言うまでもないことです。
logging, unittest のソース嫁
コメントに java へのリスペクトが書いてある
>>445 に java コンプレックスがあるのか知らんけど python は java をリスペクトして開発されたモジュールは結構多い
それをコンプレックスと思うなら python 使わなければ良い
なんかキモい
pass
451 :
デフォルトの名無しさん :2013/03/02(土) 22:34:08.83
なんでもコンプレックスに結びつけるのがユングフロイトゲガンゲン
pass
matplotlibで描いたグラフをwxPythonのパネルに表示して、 テキストボックスに入力した数字にたいして、ボタンを押して更新できるようにしたいんですが、 更新のところのやり方がよくわかりません。 plotを、再設定するだけじゃだめなんでしょうか plotまでは流れているようですが更新されません。
canvasのdrawしてないだけでした ごめんなさい。
pass
やる気があればなんでもできる
pass
pythonに適したテキストエディタを教えて下さい
無料の中ではemacsいいよね。
よいよね、だろ
いいです けっこうです
vimがもっとも優れています
早まるな。
pass
468 :
デフォルトの名無しさん :2013/03/07(木) 21:22:27.02
『初めてのPython』ぶ厚すぎだろ 3冊くらいに分けて欲しかった
xlwt を使いたいんだけどどこからダウンロードできますか? windowsです
xlwt なら、ふつうに easy_install ではいる筈。
チョーゴバク (TдT)
質問です 可変長のリストの入力に対して固定長のリストを出力したいのですが 足りない部分を先頭の要素から0で埋めようと思います 例:出力が固定長 5 のとき 入力 [1, 3] 出力 [0, 0, 0, 1, 3] 入力 [2, 1, 3] 出力 [0, 0, 2, 1, 3] 入力 [5, 4, 2, 1, 3] 出力 [5, 4, 2, 1, 3] 一番シンプルに書く方法はどんなのがありますか?
475 :
デフォルトの名無しさん :2013/03/09(土) 10:08:11.10
一番シンプルというのが怖いけど >>> def pad_list(lst, pad, size): return [pad] * (size - len(lst)) + lst >>> pad_list([2, 3], 0, 5) [0, 0, 0, 2, 3]
[0]*(5-len(a))+a
size - len(lst) が 0 (または負) になってても問題ないんですね
windowsユーザーだけど、Pythonやろうと思ってます。 Ubuntu入れたほうがいいですか? 16GBのUSBメモリでインストールを検討してるのですが どうでしょうか?
クローラとかフィードフィルタとかWindowsで開発してRaspiで動かしてる
Rubyと違ってPythonはWindowsでも問題なく使えて良いよね
484 :
480 :2013/03/09(土) 13:35:20.01
ありがとうございます m(_ _)m windowsでやります
perlのstrict機能を果たす pythonのlibrary名教えて下さい。
デコレータってどんなときに使いますか?
一番よく見るのはメモ化(memoize)かな
へえ なるほどね
再帰がわかりません。 def factorial(x): if x <= 1: return 1 return x * factorial(x - 1) factorial(5)が1×2×3×4×5で120を返すとの事なのですが、計算の流れが理解出来ません。 factorial(x -1)はどんな動きをしているのでしょうか?
>>489 x*(x-1)*(x-1-1)*(x-1-1-1)...
x<=1を満たすまで自分を呼び出し続けるだけ
x*((((x-1)*(((x-1-1)*((x-1-1-1)...
>>490 >>491 ありがとうございます。
なんとなく理解出来たような気がします。
factorial(x)に5を代入すると
return 5 * factorial(4)
4をxとして1行目に戻して最終行で
return 4 * factorial(3)
以後同じように3 *, 2 *, 1 *と入れ子が深くなりつつ繰り返され、
条件が成立した時点では
return 5 * (4 *(3 *(2 *(1))))
となるので5×4×3×2×1で120という事ですよね?
これで先に進む事が出来ます。
本当にありがとうございました。
import sys, hashlib, hmac from Crypto.Cipher import AES def aes_encrypt(msg, key, iv): encryptor = AES.new(key, AES.MODE_CBC, iv) return encryptor.encrypt(msg) aes_encrypt(encrypt.py)は、main.pyからインポートされて呼び出されます。 実行すると、ImportError: No module named Crypto.Cipherというエラーが出ます。 どうしたらいいのでしょうか? Python 2.7.3 + python2-crypto 2.6
まずsys.path確認
linuxで自作のpython野良アプリを作ったとしてそのスクリプトと設定ファイルはどこに配置するのが一般的ですか?
python関係ない linux板で聞け
linux 板の話だな conf ディレクトリ内 conf を /etc/appname へシンボリックリンク
conf ディレクトリってなんだ?
別にディレクトリにしなくても良い
conf = 設定ファイルだろ
そんな俺様ルール出されても
503 :
忍法帖【Lv=4,xxxP】(2+0:5) :2013/03/12(火) 21:10:19.36
>>464 ちなみにプラギンは?
jedi-vim?
windowsで「デスクトップ」にpyファイルを置いて importすると、日本語が通らなくてダメなの?
今の3.3はファイルシステムエンコーディングがutf-8以外のシステムで 非ascii文字がパスに含まれている場合 起動中に__main__の設定が失敗するバグがある まだ公式の修正リリースはありません
ありがとうございます。
あほ毛
3.3.1が3/2リリースだと思ってたけど、まだ出てないってことは延期されたのか 家帰ったら探してみよう
ここはお前の日記帳じゃねえんだ チラシの裏にでも書いてろ、なっ!
何を根拠に2.7とか
x. 文字コードについて PYTHONPATH\Lib\site-packages\sitecustomize.py(なければ作る)に import sys from codecs import getwriter sys.setdefaultencoding('shift_jis') sys.stdout = getwriter('shift_jis')(sys.stdout) と書くと日本語のエンコード関係がマシになるかもしれません。
ああ全然そんな話じゃない
超初心者です プログラムを身につけたいと思ったもののプログラムの種類が多すぎて何からやればいいか わからなかったのでプログラミングが学べる英語動画サイトみてたら初心者向けはpythonが多いようでした その後本屋にいくとpythonは日本ではマイナー言語のように書籍が少なかったのです pythonは日本ではマイナーなのでしょうか?pythonの利点と欠点を教えて下さい プログラムを学ぶ目的は株のシステムトレードをしたいからです
日本ではマイナーです 日本語しか読めない&読む気がないのなら他の言語にしましょう 利点と欠点より前に考えるべきことです
利点:簡単、書きやすい、読みやすい、なんでも出来る、ライブラリ多い 欠点:遅い
>>516 日本でマイナーな理由を教えてください
アメリカでメジャーってことは数年遅れで日本でもメジャーになるってことでしょ?
>>517 具体的にいうとpythonはどういう系のプログラムに向いててどういうのが向いてないの?
マイナーな理由はない。気になるなら使わないほうがいい
面倒くさそうな奴だから相手すんの止めます
そんな事言ってほんとはおじちゃんのパソコン遠隔操作する気だろ
>>521 こういうのって言質を取りたいだけでPythonを使う気は最初からさらさらないからな
>>519 ちょっとした処理の自動化には少々面倒なのでPerlとかの方が便利
各種のデータ処理に非常に強い
ループぶん回して計算しまくるようなのには全くもって不向き
いやあ、〜でしょ?〜ですよね?って同意を求めるための質問って嫌いなんですよ個人的に
やる気がないのは分かったよ。C言語やればいいよ
pass
TIOBE見ると流行りだしたのは2004年半ばになっている 数年でメジャーになるという説が正しいとすればあと1年だが・・・ だがしかし
だからTIOBE信者はJava使ってれば良いだろ
わたしPython信者ですよ? 何年で流行るとか意味不明な供述をしている方がいらっしゃいましたので 一例を提示差し上げただけですわ
他のLL使用者に感染する奇病でも流行らんことには
>>515 端金でプログラマをこき使い書かせるのが正解です
一からプログラムを学ぶのはあまりにも非生産的です
pass
本屋行ったらパーフェクトPythonと空飛ぶPythonが平積みになってたなあ 前者は一章がいい感じにすべってた
すいすいすぃ〜っと
空飛ぶputhon 超初心者用 読む価値なし パーフェクトPython 初心者用 内容が薄い
538 :
デフォルトの名無しさん :2013/03/14(木) 01:29:06.61
オライリーのPython本がいい
素養のある人間はそんな書籍に出来に関わらず上達するし、 素養のないやつにはいくら優しい入門書を書いても無駄。
超初心者用スレでいったい誰と戦ってるんだ
>>541 来週でると思うよ。
来週の何曜日に出るか知りたかったら、オライリー・ジャパンに直接聞いてみるといいよ。
ネズミ本第3版をこつこつやってます
Pythonで、Amazonの自分のアカウントにログインして 購入ボタンを押すプログラムが書きたいのですが Pythonでも出来ますか?
pythonで特定のサイト専用ブラウザ作れますか? にちゃんみたいにリクエストやレスポンスなどの仕様が公開されてません
>546 気合いと根性があれば可能だけれども,言語の選定は重要.
基本的にブラウザのリクエストとレスポンスをトレースすれば何でもできるわ 初心者にできるとは言ってないことに注意しろ
Pythonそのものに加えてHTTP、場合によってはAjaxを含むjavascriptまで 本当の本当に言語一個もやったことがない初心者だと1年コースだと思え
pythonを勉強したいと思った超初心者です>< ネットブックをpython勉強専用機にしたいと思っています そう自分は形から入る性格です まずarchlinuxを入れました pythonだけ出来ればいいのでX環境は入れないで良かったのですが consoleで日本語が使えません>< そこでjfbtermを入れてみました w3mも見れるしそこで問題は解決したのですがやっぱり物足りない感 そこでWMでタイル型なんて入れたら良いのかな?と思ったのですが 調べるとpythonで書かれたWMがありました→qlite じゃあいっそpython関係のアプリだけを今後インストールしたいと思いました X環境とqlite以外入っていない状態です 何かpythonアプリで良いものを教えてくださいm(._.*)m
Selenium があるね。
>>550 誰が見ても超初心者ですね
uzblやwmiiがPython(というか任意の言語)で拡張できて楽しいよ
qtileならpython-xlibが依存関係で入ってるからそれで遊べる
うわー超初心者に教えてもらっちゃったよ
qliteなんてもんがあるんだーうわー
俺はsqlite3の書き間違いだと思ってたよ、うわー恥ずかしー
って思ったけど良く良く
>>552 を見てみれば、qtileって書いてあるじゃないか
初心者に試された!
554 :
デフォルトの名無しさん :2013/03/14(木) 16:39:14.07
Python() 開発効率的にも実行速度的にもPHPのほうが有利なのに
pass
>>545 ありがとうございます
アマゾンのページのhtmlのソースとかを読んで
ボタン名とかを把握して、クリックする感じになるんですかね?
Python以外の言語の方がやりやすかったりしますでしょうか
Mechanizeみたいなのが他の言語にあるかどうかじゃね。
>>556 > アマゾンのページのhtmlのソースとかを読んで
> ボタン名とかを把握して、クリックする感じになるんですかね?
基本的にはそう、mechanizeとかね
webkitを使えばログイン画面をそのまま表示して入力させたりajaxサイトにも対応出来る
> Python以外の言語の方がやりやすかったりしますでしょうか
どの言語もやり易さは大体同じだけど、シンプルなpythonが一番わかりやすいよ
559 :
デフォルトの名無しさん :2013/03/14(木) 19:01:55.35
>>556 そりゃパイソンスレで聞けばパイソンが一番やりやすいって答えるよ
実際はPHPが一番楽
生きてて恥ずかしくないんだろうか
561 :
デフォルトの名無しさん :2013/03/14(木) 19:13:55.18
一言でプログラマって言っても色々だからね MSで働いてるような凄腕プログラマもいれば 林檎で働いてるゴミグラマもいる
pythonファンだけど
実は
>>556 の質問には
node.js が最適と答えざるを得ない
Microsoftの社員はどちらかというと秀才タイプ Appleみたいな強烈なセンスある天才やジョブスみたいなカリスマは残念だけどあまり居ないね
ジョブズは、悪人
アポーには居るのか?
pass
MSはヘルスバーグがいるじゃないか 神扱いされてるプログラマの一人だけどまあ地味なのは否めないな
;
pythonのアンスコ乱用が気持ち悪い 作者には美的感覚が無かったのか
easyなんとかとかで入れたパッケージを アンインストールする方法はありますか?
アンインストールコマンドがあるPyPIの方が良いね
>>569 個人的にはlowerCamelCaseの方が気持ち悪い
PascalCaseとアンスコだけでいい
pass
pythonのインストールから実行環境を整えるまで アホのオレには一苦労だったわ 他の言語で慣れてる人には、楽勝なんだろうな〜
pass
今更なんだけどなんで互換性無くしたの?
互換性を保ったままにできなかったから
3.xがマルチコアマルチプロセッサ対応だったら今すぐ2.7から乗り換える
一生2.7でいいじゃねえか 何か不満か たぶん2.7の期限が来ても誰かがサポートつづけんだろ
2.7は文字コード周りがウンコ
せめて拡張子変えてくれれば使うのに
windowsはシェバン使えないから不便だな まあ3系にはシェバンを理解するランチャが付いてるんですが
拡張子なんてもともと大した意味ないだろ pyである必要性すらない
wxPython のエラーが表示されるwxPython: stdout/stderr ウィンドウが 応答なしになってデバッグしづらいです。 応答なしにならないようにする、または出力先を idle に変えるような方法はありますか? 環境は win7 64 bit, python 2.7.3, wxPython2.8-win32-unicode-2.8.12.1-py27 で idle から実行しています。 例えばフレームのタイトルに "日本語文字列" などを unicode にしていない場合のエラーでも wxPython: stdout/stderr ウィンドウが応答無しになりエラーメッセージがスクロールすらできません。
>>587 pyscripterならwxのエラーも出てるけど
>>855 PyScripter-v2.5.3-Setup.exe からインストールしてやってみました。
こちらだと例外ダイアログは正常に閉じれますが、別に表示される wxPython: stdout/stderr は
マウスを近づけただけで応答なしになってしまいます。
コマンドプロンプトからスクリプトを実行したらどうなるの?
>>590 python test.py として実行したら、 wxPython: stdout/stderr ダイアログは表示されませんでした。
エラーメッセージがコマンドプロンプトに表示されましたが、ダイアログに表示されたものではありません。
もしかしたらダイアログに表示される最初のメッセージなのかもしれません。
>>588 バグの原因は文字コードではなく未定義の配列要素へのアクセスが原因でした。
修正したあと別のエラーによってダイアログが表示されましたが、固まらずにエラーログが表示されました。
バグの内容によって応答なしにはならないので、このまま PyScripter を使おうと思います。ありがとうございました。
593 :
忍法帖【Lv=5,xxxP】(1+0:5) :2013/03/16(土) 11:59:06.25
みんな何で書いてる?Eclipse?
>>593 Eclipse + PyDev + CVS
xyzzy
>>581 3.xは文字コード周りが「枯れてない」ので
どっちも面倒くさいことになるのはいっしょ。
まだ対処可能なケースの多い2.xの方がマシ。
3.3でかなり改善はされたけど、
おかげでバグが激しくて3.3.1待ちの状態。
2.7でも3.2でも文字コード廻りで対処できなかったケースないわ 3.3はまだ地雷だけど
馬鹿には無理
と馬鹿が申しております
あららー?
間もなく6ヶ月なのに、まだrcの気配もないよ>3.3.1
2.xの文字コード周りが明らかに糞仕様だと認めない人が何を言いたいのか殆ど理解できない
>>593 emacs + auto-complete
枯れてる枯れてないの議論をすれば、確かに2.xの文字コードは腐りきってるけど、糞仕様には変わりないんだよ
自分が扱えるから糞仕様じゃないって事じゃね 100回まわさないと水が出てこない蛇口でも使えるから糞仕様ではないって言うよ、たぶん
初心者なのでPyScripterでやってます・・・
PyScripterはWin限定だからスルーされがちなだけで無茶苦茶優秀なエディタ
>>593 Notepad++ プラグインのPython Scriptを入れて
NppExecプラグインは便利
F6 python $(FULL_CURRENT_PATH) Enter
一行目に NPP_SAVE を加えれば Ctrl+S の手間も省けるしね
PythonはWindowsもちゃんとサポートしている言語ですか? RubyみたいにWindowsは中途半端にサポートしてますか?
Rubyよりは相対的にマシだけどそれでも開発者からは嫌われてる
Windowsベッタリで行くならIronPythonもあり 2.7ベースだけど
IronPythonでimport zlib, sqlite3とかできるの?
Linuxでpythonを勉強しはじめました。 ncursesを使った簡単なプログラムを作りたいと思ったのですが その簡単なサンプルみたいなものも情報も少なく感じています。 何かおすすめみたいのがあれば教えてください m(_ _"m)
馬鹿には無理
そんなひどい
>>618 一応Cのライブラリには対応してたはず
最悪.NETのライブラリも使える
たしかtkinterはデフォルトで無かったけど、 GUIは.NETの使えば良いかなーって感じ
>>619 プログラミング初心者の俺でもそのくらい分かる
626 :
デフォルトの名無しさん :2013/03/16(土) 23:21:57.85
3系の質問です。 L = [] for i in range(10): L[i] = "abc" + str(i) print(L) 上記を実行して以下のようなリストを作りたいのですがうまくいきません。 ["abc0","abc1","abc2",…,"abc9"] どうすれば意図する事が出来るでしょうか?
L = ["abc" + i for i in range(10)]
方法は3つ
(1) L = [] → L = [None]*10
(2) L[i] = "abc" + str(i) → L.append("abc"+str(i))
(3)
>>627 ( i をキャストしてないけど)
(3)のリスト内包表記がベスト
あと、文字列の結合は ''.join(list) を使ったほうが良い
つかバージョン関係ねえ
pass
L = [''.join(['abc',str(i)]) for i in range(10)]
map(lambda x:'abc%02d'%x, range(20))
joinは汚ない。10回程度なら書きやすさ読みやすさを考えて + でも全然いいよ
何回程度ならダメなんだよ
女陰は汚い。
pass
>>626 L = ["abc%d" % i for i in range(10)]
なぜ人が書いてることをまた書くのか
脳が腐敗してるから
L = map(lambda x:'abc%d'%x,range(10))
["abc{}".format(i) for i in range(10)] list(map("abc{}".format, range(10)))
もういいぞクズ
TIMTOWTDIですね。わかります
同じこと連呼してドヤ顔とか… データ構造やアルゴリズムを変えてみてから言えよ
文字列リテラルにメソッド呼び出しするの気持ち悪い
オブジェクトがメソッドを持つのは当然のこと
手続き脳にオブジェクト指向やらすと起こる定番の拒否反応
648 :
忍法帖【Lv=6,xxxP】(1+0:5) :2013/03/17(日) 18:26:55.10
map関数は気持ち悪いなあ どこがどうと言えないのだけど
オブジェクト脳に関数型やらすと起こる定番の拒否反応
>>648 os.path.joinの第二引数がリストになってるよ
map, filter, reduceに慣れてないだけw
論理的には文字列にメソッドは気にならないんだけど コードの見た目が壊滅的に気持ち悪い 記号の演算子乱用する言語と同じくらい気持ち悪い
なぜ気持ち悪いのか、どう気持ち悪いのか言えよ。ただの馬鹿じゃん
mapは文字通り集合から集合への写像なのに何が気持ち悪いのか理解不能
生理的嫌悪感を感じるんだ これは不細工が嫌いとかそういうレベルの感情だからどうしようもない
それならpythonを使うべきではないね。仕事なら別だが
mapは気持ちわるくないけど map("abc{}".format, range(10)) ともなると "abc{}".format のアリティが文字列リテラルの中の {} の数によって決められるのがあれかも
map()が気持ち悪いってプログラミングセンス皆無だぞ
append とか join はぜんぶ関数にしてほしい。 append(lst, elem) join(lst1, lst2) とかしたい。
>>660 joinを呼ぶ文字列は区切り文字であってリストじゃない
つまりlst1とlst2を連結するメソッドではない
アホか むしろシーケンスがlenメソッド持つべきだろ 頭湧いてんのか
>>661 文字列の連結は + にしてほしい。
str1 + str2
えっ?
えぇ
もともとそうだったか。
>>663 だからそれは出来るだろ。処理系によって滅茶苦茶おそくなるが
というか、お前はPythonやオブジェクト指向言語を使わないほうが良いと思う
まあ、オブジェクト指向だからこそ演算子のオーバーロードができるわけだから
もうプログラミング辞めたほうがいいと思う
この程度の頭で喋ってるのかい。
呆れたからご飯のし支度でもするわ
# unko.py def append(a, e): a.append(e) def join(s, a): s.join(a) def map(*a, **b): raise Exception('Hey motherfucker! Do NOT use "map" function.') from unko import *
>>627 >>628 ありがとうございます。
リスト末尾への追加はappend()を使うんですね。すっかり頭から抜けていました。
(1)のL = [None]*10
を使って最初のループに当てはめてみてもうまくいきました。
メソッドを使わずに代入だけでリスト内の構成を変えようとした事が失敗の原因だったんですね。
まだ内包表記まで進んでいないので内包表記は後日見直してみます。
本当にありがとうございました。
>>670 append([1, 2, 3], 4) の結果はどこに行くの。
どっか行くの?
>>659 何で?
こんな変な動作をする関数は
Cなどの従来一般的な開発言語にはないでしょ。
append(a, e)のaやreturnを書き忘れるあたりおそらくRuby初心者スレじゃないかと思う
list.sort()とsorted(list)の違い
lispってCより15年近く古いよね
>>673 append([1, 2, 3], 4) に返して欲しいのは [1, 2, 3, 4] だよ。
implicit に a を書き換えるんじゃなくて。
関数定義するならこんな感じ。
def append(a, e):
return a + [e]
map関数がやってることもこれとほぼ同じなんだけど何故かしっくりこないらしい 人間の脳味噌って不可思議だね
>>681 じゃあ、a.append(e) に何の意味があるんだ?
とりあえずうるさいから全員黙れ 嫌なら使うのやめろ 士ね
>>684 a のメソッドであることにどんな意味があるの?
>>680 の「これ」が
>>679 だとしたら
mapにたいして深刻な勘違いをしていると言わざるを得ない
>>686 リストしか使わない処理だから。読むときも書くときも他のことを考えなくて済む
リストを継承したクラスでも同じことが出来る
>>660 みたいな馬鹿には一生わからないだろうが
pass
とりあえずうるさいから全員黙れ 嫌なら使うのやめろ 士ね
pass
盲人の手を引く盲人
ここまで俺様の自演w
while 1: pass
>>697 じゃあなんで len は lst.len() みたいにならないんだ?
ぜんぶメソッドに統一すればいいじゃないか。
str.len()も無くて最初探しまくったのは悪い思い出
Ruby のせいですね わかります
.NETやJavaもそうじゃないか。まあどっちでもすぐ慣れるのだけど
.NET や Java がそうだから Pythonも、ってのは理由にはならないだろ。
L = map(lambda x:'abc%d'%x,range(10))
うるせえ死ね
>>701 それ読むとグイドは x.len() キモイって言ってるけど、
同じ理由で lst.append(elem) もキモイんだけど。
それと、lst.append(elem) が lst の内容を陰に書き換えるのもキモイ。
ヴァンホーテンさんはBDFLとして何かおもしろいこと言わなきゃいけないんだから 発言に多少齟齬があっても気にしないのが大人としての優しさ
Pythonのメソッドをぜんぶ関数にしたらカッコのないLISPになっちゃう。
lst += [elem]
708 :
忍法帖【Lv=7,xxxP】(1+0:5) :2013/03/18(月) 08:36:15.99
>>704 副作用があるときメソッド、副作用がないとき関数。
例:lst.sort() と sorted(lst)
str.unicode() は?
unicode(str)は副作用がないが str.decode()も副作用がない
下らないこと書いてないで働けよ社畜ども
フリーランスですが何か
最近はフリーのニートとかあるんだね 僕?お昼休みですけど ところでお前ら死ね
len()やmax()はリスト以外にも同じように使える appendはリストだけの操作だから全体に使えるようにする意味がない 全て関数にすべきとか、もうクラスを一度も書いたことがないC言語しか知らない人間の言うことだから どんな議論も無意味だけど こんな瑣末なことが気持ち悪いと思うのならPythonは使うべきではない ま、そんな奴は全ての言語について何かしら本質でないことに対して気持ち悪いと言うのだろうが それをハッカーがよくやる真っ当な言語ディスだと勘違いしてるのならご愁傷様
Guido脂肪w
そもそも le nが string にも list にも同じように使えるのがおかしい。
どこが?
string ならリストに変換してリストの len を取れば足りるだろ。 "abc" → ["a", "b", "c"] → len(["a", "b", "c"]) → 3 みたいに。len が string の長さを測る必要ない。
string[i]でアクセス出来るのになんでリストに変換しなきゃいけないのかとw stringに対して酷い誤解をしてるよ
i が分かるのは string の長さが分かってるからでしょ。
だから for i in range(len(list)): list[i] は出来るのに for i in range(len(string)): string[i] がダメな理由は何? 馬鹿すぎてお話にならないが
最低限与えられるファンダメンタルな機能としては不要だってこと。
そう思うのならPythonを使うべきではないね、残念ながら。
それはおまいが決めることではない。
>>724 こそお前が決めることではない
そう決めるのならPythonを使うべきではない。それだけ
今回の議論でいろいろ Python の問題点が見えてきたよ。 それらはすべて自分のライブラリにフィードバックしてるから。 ありがとう!
プロフェッショナルが作った洗練された組み込み関数を 全て台無しにする糞ライブラリの完成だなw
組み込み関数に対して自分用のラッパ書くとかもはやなんでその言語使ってるのか分からないレベル
結果が同じでも色んな書き方あるようだけど やっぱ速度も違ってくるのかな?
糖衣構文でもないかぎり速度は変わるに決まってる
もちろん >>> from timeit import timeit >>> timeit(' ["abc" + str(i) for i in range(10)] ') 12.046442985534668 >>> timeit(' ["".join(("abc", str(i))) for i in range(10)] ') 16.259288787841797 >>> timeit(' ["".join(["abc", str(i)]) for i in range(10)] ') 19.62903094291687
ソースコードは Python の実装(PyPy、Jython、IronPython、Pyrex、 Psyco など)ごとの欠点を引き出さないように書くべきである。たとえば、 CPython が a+=b や a=a+b などの文字列連結をインプレイス処理して、効 率よく動作する実装に依存してはならない。これでは Jython での動作が遅く なってしまう。パフォーマンスに敏感な部分では、''.join() を使うべき である。こう書いておけば、様々な実装において、連結処理は線形時間で 処理できる。
使いもしない処理系のことを考えてプログラミングするの?やだー
俺は使うけど?
>>737 じゃあその使ってる処理系でベンチやってくれ。
>>739 文字列にがんがん文字列追加してく例じゃん
そりゃjoinのほうが早いよ
2ちゃんねるのダメ系の板にしばらくいたことがありますが、ダメになる傾向って確かにあって一つしかないですね 何もしないことです 怠惰や失敗への恐れや他人への迷惑への懸念、大元の理由は様々ですが あそこにいる人たちの共通点は何もしてこなかった事に尽きます
書き捨てのコードで実装依存がどうたらと真面目に考えてるのか? 仕事しろチンカス
主にライブラリ作者が気をつけてればいい話だ罠 自称意識高い系で、有名プログラマとか本の受け売りばっかり頭に叩き込んでる奴が 皺のなくなった頭とドヤ顔でこういうことを喋ってる たまに勉強会で見かける
レベル低い奴の言い訳は見苦しいなあ
馬鹿の一つ覚えって言っておけばすべて解決
受け売りで自分で喋れない蛇口君よりは大層ましだと思うぜ
俺「PEP8に書かれてますよー」 馬鹿「受け売りはやめろ」
俺と馬鹿が逆ですよ
これぞ思考停止
ここにいるカスどもからはPythonコミュニティには絶対にコミットしないという強い意思が見える そのくせ開発者には文句たらたら(しかもそれは自分の無能さが原因)。死んだほうがいい
使ってやってるんだからありがたく思え。禿げ上がれ。
するわけないじゃん。 お前工具の開発元にいちいちフィードバック送ってんの? へーすごいね。えらいね。帰っていいよ。
フィードバック送るのは当然ですしおすし
ふーん そのコミュニティとやらはお前に何か尽くしてくれんの? 葬式に来てくれるとか? そうでないなら労力を吸い取られてるだけの単なる物好きだね 大したものだ
で、その経験はお前の中に何を形成したの? 何か強みになりましたか?
おまいらPythonに関係のない話続けるならまとめてどっかいってくれませんかね
全員葬式の準備をしろ お前らは強制的にあの世行きだ
コミュニティへの貢献が関係ない話のわけがないだろ。 ユーザーの意識が今後の発展にかかわるんだ。
>>758 罵倒する語彙も不足してるらしいな。よく分かるぜ。
まあフィードバックと称したクレームはこのスレにも要らないけどね
ここイシュートラッカじゃないんで、文句言われても困るわ 言語仕様についてならコミュニティで大いに語って来いよコミュニティバカ
>>760 罵倒じゃなくて
>>751-752 ,754-755みたいなレスをしちゃう人間の脳みそを本気で心配しているのだが
Python関連の何かに親でも殺されたのか?怖いよ
俺もなんのメリットもなく貢献貢献と自慰できる人間の脳味噌に本気で興味を抱いてるよ 一週間前にも居たよな 公開オナニー馬鹿が全国に
>>764 フィードバックのデメリットって何?
自分が使おうとしてるプログラムやソースコードのことで気づいたことでしょ?
わざわざ自分と関係のない問題を見つけ出すわけじゃないよ
なぜフィードバックにブチギレてるのか理解不能w
誰かデメリットの話をしたか? 誰だ?出てこい
>>754 >そうでないなら労力を吸い取られてるだけ
そりゃ尤もなデメリットだな 労力を削く以上に根本的なデメリットは無いよね 否定していいぞ、できるなら
何の労力?
いつまで続くん
どちらかの賢さが1上がるまでだな
フィードバック=デバッグ作業だと思ってるキチガイが死ぬまでだな
PEP8の話の方がまだ面白い
>>750 無能な働き者がコミットしまくるよりいいんじゃないの
それ以前に無能は死ねよ このスレ存続の危機だろうけどな
>>775 うん、このスレに上がってるような不満や問題点の指摘は的外れすぎて絶対にコミッターにはなれないし
なんでPythonを使ってるかも分からないレベル
それくらい言語への理解が至ってないのに、何故か偉そうで意味が分からない
質問者ではないようだし、自分では初心者だと思ってないらしいから質が悪い
2chに書き込む「労力」が無駄
こんなスノビー臭い言語使ってる理由なんて推して知るべしだろ 考えるより自分の胸に手を当てた方が早いんじゃないか
>>779 お前がお前の胸に手を当てて分かることなんて俺は知らんよ
このスレにコミッターなんておらんだろうに、偉そうなモブ1号が何事かほざきおるな ぐらいにしか聞こえない
コミッターになれないって あれなりたくてなってるものだったの? 罰ゲームだと思ってた
葬式に来てくれない相手にレスするなんて、モノ好きだねえ
>>783 よく何も知らないことに対して自信満々に嘘八百が並べられるな
生きてて恥ずかしくないんだろうか
何の罰だよ意味わかんねえ
>>779 昔は人生の落伍者でも使える言語との評判でした
葬式なんて遠い未来のことなんぞより今ここだろ 今でしょ!の先生も言ってるだろ まあ、今何かする暇があるってことは 今の作業を事前にスケジュールできていなかったわけで アレ見た社会人がネタじゃなくマジ感銘受けてられると いろんな意味で参る
落伍者どころかクソ袋でも使えるようになったし 時代の進歩を感じるね
790 :
731 :2013/03/18(月) 20:15:06.34
速度の話しから変な方向に広がってしまったな すまんの
ええんやで
ソーシャルなんとかの流行で有象無象が流入してきてんのかな 移住するか
移住も何も昔からここが最果て、いちばんカスの集まる場所だよ
ここに地終わりゴミの海が始まる
騒がしいのが苦手なんで Haskelでも見てくるか
lispでいいんじゃないの
オランダじゃないのは確かだ
ソーシャルなんとかってなんだ。
1.2 + 1.8 の小数同士の計算が こんなに難しいとは・・・
前後が無いと何が難しいのかわからない
>>> 1.2 + 1.8 3.0
階乗進数(n桁目がn!)を使うと浮動小数点数の変換誤差は無くなるらしい
805 :
デフォルトの名無しさん :2013/03/20(水) 09:00:11.41
pythonではイテレートの終了を示すために特殊な例外を投げますが なぜこのような奇妙な仕様になったのでしょうか
戻り値やプロパティを使って判断するのに比べて実装が楽だし綺麗だから C#やJavaなんかは戻り値やプロパティを使ってるが、 それらに比べてもともとクソ遅いので例外のパフォーマンスヒットを無視できるから
Rubyは内部イテレータだから例外使わないと実装しづらいんだけど Pythonは外部イテレータ(C#やJavaと同じ方式)なので実はそうでもなかったりする next()一つで済むという一点だけだな
809 :
デフォルトの名無しさん :2013/03/20(水) 12:15:21.45
pythonの優れた点ってインデント強制だけだよな
Python好きだけど別にそこは優れてると思わん
リスト内包表記のシンタックスを考えた奴は天才 メソッドチェインやらラムダやらSQLもどきやらで同じことやってる言語は色々あるが ここまでしっくりくるのは他にない
Pythonオリジナルではないので注意
ハスケルが元祖なんだろ?知ってるよ
smalltalk
小人さんはまだ2つの数字しか覚えてないから許してあげて
>>816 計算結果はおかしくありません。コンピュータにおける浮動小数点のしくみを理解しましょう
あとこのような質問はあまりにも基礎的なのですでに多くの質問と回答がネット上に上がっているはずです
事前に検索する癖をつけるか計算機の基礎知識を身につけてください(「コンピュータはなぜ動くのか」を読むことを勧めます)
コンピュータはなぜ動くのかってよく勧められるけどかなり退屈な本だよね 基本情報技術者を受けたほうがはやい。これもクソ退屈な試験で過去問みるだけで受かるけど その過程で浮動小数点とか基本的なことは大体知ることができるし、何の役にも立たない資格が貰えるオマケ付き それよか実際に重要なのは厳密な解が欲しいときに 例えば計算のすべてをint型でやるようにアルゴリズムを考えなおす等のプログラミングテクニックかな やり方は問題によるけど競技プログラミングではよく出くわす
頭の悪い奴は口先がよく動く
訳「ぎゃふん」
小数なんか全部10進小数でもいいと思うけどな スクリプト言語の演算速度なんてどうせほぼ無視できるんだから
デシマル最強伝説
10進浮動小数点数を既定で使うスクリプト言語って聞いたことないけどなんで無いんだろ pythonのdecimalモジュールみたいにライブラリでやると演算自体のコストに比べて 諸々のオーバーヘッドがとんでもなく大きくなるからなあ 10進演算が組み込みで速いって結構メリットだと思うけど
>824 コメンテーターがあほばっか
少なくとも俺は12年floatで困ったことが無いから今後も困らないだろう
10進小数なんてメリットあるの金融関係位だろ
積分とか適当にやると誤差すごい
newton法試したけど誤差すごい
一連の話題の目の付け所が誤差すごい
834 :
デフォルトの名無しさん :2013/03/23(土) 15:12:14.36
質問ですが、forループ内で変数名を文字列に変換することはできますか? 例えば for i in [Firefox, Chrome, Opera, Safari]: のループ内で、それぞれの変数名の最初の2文字(FirefoxならFi)を文字列としてループ内で他の変数に格納することは可能でしょうか?
んなバカなことしなくてよろしい 辞書使え
変換する必要ないと思うよ どういう時にそんなことしたくなった?
そんなことしたいと思わないな
838 :
デフォルトの名無しさん :2013/03/23(土) 15:26:34.67
回答ありがとうございます。 それぞれの変数はstatsmodelsのolsで回帰分析をして作成したもので、ループ内ではpandasのデータフレームに、変数名の最初の2文字をカラム名、.params属性で出てくる値をカラムの値として1つずつ繋げて1つのデータフレームとしたいのですが、他に良い方法はありませんか?
そんな事したいと思った事がないという答えとか酷いなwww
どうしてそういう考えに至ったのかを考察する事が重要ですね
よく分からんけど、 for k, v in locals(): if isinstance(v, statsmodels): print('k[:2] =', k[:2], 'v =', v) これでいいんじゃない? 個人が趣味でやる分には構わないと思うけど、 他人が見たらなんのことやらさっぱり。
842 :
デフォルトの名無しさん :2013/03/23(土) 15:56:25.24
>>841 ありがとうございます。しかしこのやり方だと含めたくない他のstatsmodelsから生成されたインスタンスも含めることになってしまいますよね?
今回はループを使わずに1つずつ手作業で指定して当分はしのぐことにします。
皆さんありがとうございました。
>>842 よく分からんけど、
for k, v in locals():
if k in ['Firefox', 'Chrome', 'Opera', 'Safari']:
print('k[:2] =', k[:2], 'v =', v)
これでいいんじゃない?
例とことわったコードを実際のコードと思い込んで「バカなことしなくてよろしい」とか突っ込むってバカの極みだろう。
いやばかだし
質問者が解決したって言った問題の回答者達に後から突っ込むってバカの極みだろう。
いいえ私がバカの極みです
いえいえ私が
えっ・・あ、それじゃ俺も・・・
やーいやーい
問題はバカなことだと気付いていない事なんだよなぁ これ他人事じゃないのよ
普通はここ以外で馬鹿と接点がないから 自分のことだけ気をつけてれば大丈夫
たまにこういう流れになるなこのスレ 質問の前提を変えずに解決法を提示するという当たり前のことがわかってない人が若干名いるんだよね 「そんなことするな」「やらなければいい」って猿でも言える 馬鹿な人ほど問題の前提をひっくり返して解決した気になるって誰かが言ってたけど至言だと思う 解決策が思いつかない自分の駄目さから無意識のうちに目を背けようとしてるんだってさ
>>842 if v in [Firefox, Chrome, Opera, Safari]:
でいけるはず、やってみそ
学校のお勉強じゃねーんだから、 質問の前提を変えちゃダメなんてルールは無い 馬鹿げた質問には馬鹿だと教えてやるのが親切ってもんだ
2行目は同意だが3行目は全く同意しない カスの世話だ
まあどうせ自演なんだし
イ`ヘ /: :| ヽ / : :/ ヽ ___ _,,,:. .-: :´彡フ _ノ\_∠: : : : : : : : :`: :-: :,:_:/彡 / ( : : : : : : : : : : : : : : `ゝ / マ r::/: /: : | : : : : : : : : ::\ / //: /: : : |: : | |: : |: _: : : :ヽ ジ {/ 7|`\/i: /|:|/|´: : : : :|ヽ 〉 ,‐-‐、`|7 || |_::|,_|: : :|:::|: | で / r:oヽ` /.:oヽヽ: :|: | :| { {o:::::::} {:::::0 }/: :|N っ | ヾ:::ソ ヾ:::ソ /|: : | !? ヽ::::ー-.. /ヽ ..ー-::: ヽ::| r--ッ -tヽ/´|`::::::::::;/ `、 ::::::::::: /: i } > ::∧: : :|: |J \ / /::i: | /_ゝ . \ヾ: |::|` - ,, ___`-´_ ,, - ´|: : :|:::| ヽ: |::|\  ̄/ /| |: : :|: |
>>853 そもそも管理すべきデータを間違ってとらえているから
変数名をデータとして扱いたいなんて要求が出るんだよね。
これは完全に設計上の謝りで、質問の前提を変えるなどという問題ではないよ。
特にこの場合は初心者特有の間違いだから、回答としては「そんなことするな」が正解。
ちなみに質問の前提を変えて問題を解決するなんて、馬鹿には無理。
誰も正解なんて質問してねーんだよ 痴れたことを
モヒカンは精神的な欠陥を抱えてて歩み寄りを絶対にしないので、無視すんのが正解。
>>859 ここは「くだすれPython(超初心者用)その16」というスレ
超初心者には馬鹿に見える秀才君がたくさんいます
超初心者には「そんなことするな」という回答が理解できません
>>859 はスレチ
無視すんのが正解つったろーがタコ。
>>862 なんだ荒らしたいのか?変な人に絡んでしまった。
待ってましたとばかりにアンカー付けちゃってンモーww
わからなかったら入力データと出力形式だけ書けばいいんだよ そうしたら最適なコードを書きたい人が書いてくれるから
Windows用のPythonってインストーラー形式しかないんですか? zip形式のってないんですか?
portable python
普通になかったか
2.7.4 RC1来てるやん
871 :
デフォルトの名無しさん :2013/03/25(月) 14:48:14.02
質問です。宜しくおねがいします。 オブジェクトをメンバーに持つオブジェクトがあったとします。メンバー側のオブジェクトから親のオブジェクトを参照する 方法はありますか? 例えば import random class Ko(object): def __init__(self,a,b): self.a=a self.b=b class Oya(object): def __init__(self,x,y,z) self.kodomo=Ko(x,y) self.z=z kodomotachi=[] oya1=Oya(1,2,3) oya2=Oya(3,4,5) oya3=Oya(31,41,51) oya4=Oya(11,21,31) kodomotachi.append(oya1.kodomo) kodomotachi.append(oya2.kodomo) kodomotachi.append(oya3.kodomo) kodomotachi.append(oya4.kodomo) kodomotachi.remove(kodomotachi[random.randint(0,3)]) としたとき、kodomotachiリストはOyaオブジェクトのインスタンスのkodomoメンバで構成されてる 訳ですが、たとえば上記のようにkodomotachiリストの内容が不明な時に、 kodomotachi[2]などから親オブジェクトを参照する方法はありますか?
混乱してきた・・・ parentとchildで書き直して
873 :
デフォルトの名無しさん :2013/03/25(月) 15:44:09.12
>>871 KoクラスにOyaインスタンスへの参照を保持する変数を入れとけばいいんじゃないの
874 :
デフォルトの名無しさん :2013/03/25(月) 15:58:31.87
hogoshakai = [] hogoshakai.append(oya1) hogoshakai.append(oya2) hogoshakai.append(oya3) hogoshakai.append(oya4) o = [oya for oya in hogoshakai if oya.kodomo == kodomotachi[2]]
はい、次
o = [oya for oya in locals() if isinstance(oya, Oya) and oya.kodomo == kodomotachi[2]]
何この拷問 import random class Ko(object): def __init__(self,a,b,c): self.a=a self.b=b self.c=c class Oya(object): def __init__(self,x,y,z) self.kodomo=Ko(x,y,self) self.z=z ... kodomotachi[2].c ハァハァ、、、ツカレタ、、、ハァハァ タメシテナイカラ、ダメダッタラゴメンネ
878 :
871 :2013/03/26(火) 08:57:54.62
>>874 >>876 >>877 みなさん有り難うございました。実はpymunkという物理エンジンを簡単に使うために、○とか□とかの物体をpymunk純正のshapeとかbodyとかのオブジェクトと
ともにpygameの描画メソッドつきのクラスにした自分用ラッパーライブラリを作っています。
pymunkの世界(space)にshapeとかbodyとかの物体情報をappendしてくんですが、衝突判定機能なんかで登録したbodyなどの純正オブジェクトは返り値として
得られるのですが、それらを内包する自作オブジェクトを得る方法はないかと悩んでました。
と言う訳で、メンバ側のオブジェクトは改造しづらい状況なので874さん、876さんの方法でいってみます。
でも877さんのメンバ側のオブジェクトに親オブジェクトの情報を持たせる方法も目から鱗でした。
みなさん、有り難うございました。
1.Python覚えたいんですけど何で日本ではRubyが流行ってるんでしょうか? 2.RubyでいうRailsみたいなフレームワークはPythonではなんでしょうか? 3.PHPでいうPear、Rubyでいうgem、Pythonではなんでしょうか? 4.今からPython3.3で勉強しても問題ないでしょうか? 5.RubyでいうHerokuみたいな無料で使えるクラウドがありますがPython3.3が動くクラウドってありませんか?
6.PythonはWindowsでコードを書いても問題ないでしょうか? 7.PythonではテキストエディタとIDEどっちを使うほうがいいでしょうか? 8.Pythonの定番のGUI作成ライブラリってありますか? 9.Pythonで構築されたサイトのまとめってありませんか?python.jpで公式に取り上げてませんか? 10.文字コードは基本utf8bomなしで改行コードはLFでコード書くものでしょうか?
1. 日本人は英語出来ないから 2. django 3. pypi, easy_install 4. 大丈v 5. あります 6. 問題ない 7. 俺はvim 8. tkinter, qt 9. python.org 10. yes
テンプレに入れてください
日本人の大半はマニュアル英語すら読めないから Djangoとか PyPi ほとんどローカルでしか使えないと思うけどそれでよければ ない いいよ 両方使ってみて自分に合う方 Python3希望しているなら今のところ諸手を挙げたお勧めはない 日本語の資料を希望しているならない そんな制限はない
あえてPythonを使う積極的な理由はありますか? どうせいやいや使ってるんでしょう?
このスレはこういう煽りに来たお客さんに真面目に答えてる馬鹿がいて偉いなあと思う
886 :
デフォルトの名無しさん :2013/03/26(火) 14:13:34.27
>>884 俺はRuby/PHP/Perlがキモすぎて嫌だから。
適用分野はかぶっているので、Python嫌ならRuby/PHP/Perl使っとけばいいんじゃね?
>>885 それが「Pythonコミュニティー怖い」と言われる所以かもな。
コミュニティ障碍
890 :
871 :2013/03/26(火) 16:38:40.97
>>886 同意。
キモいと言われるかもしれないが俺もPythonは楽しいです。
とっかかりは簡単でも奥が深い(俺が浅いのかも)言語だと信じてます。
objective-C、JAVA、JAVAscriptと挫折した俺だけど、Pythonではちょこちょこ作れてます。
Ubuntuに3系のPythonをインストールするともともと入っている2系とトラブルを起こすというレスを見たのですが、ソフトウェアセンターからのダウンロードでも状況は同じでしょうか?
>>891 問題は起きない
「python3」の名前でpathが通る
893 :
879 :2013/03/26(火) 23:02:26.32
ありがとうございます
>>892 ありがとうございます。
これで安心してインストール出来ます。
>>890 Pythonは書きやすいし読みやすいからストレスが貯まり辛いよね
多分Rubyでも同じような印象を受けると思う
PythonとRubyはプログラミングの入り口に最適だと思う
>>891 ちなみにUbuntu12.10だとデフォルトでpython3.2が入ってるので楽だよ
「python3」で3系 「python」で2系にpathが通ってる
やはりpythonの本流は2.Xだな
>>895 本当に入ってました!
ありがとうございます。
疑っとったんかい!
疑って掛かるのはいいことだぞ〜 ここをどこだと思ってる
下のphpコードpythonでどう書くのか教えてください! class A { private $str; public function setStr($s){ $this->str = $s; } public function getStr(){ return $this->str; } protected test1($n) { return ($n + 10) * 2; } private test2($n) { return $n * 2; } }
class A: def __init__(self): self.__str = None def setStr(self, s): self.__str = s def getStr(self, s): return self.__str def test1(self, n):#protectedは無い return (n + 10) * 2 def __test2(self, n): return n * 2
メソッド名がアンダースコアから始まるものは外部に非公開とみなすコーディングスタイルがある(pep8)
>>902-903 JavaとPHPからPythonくるとなんか違和感がありますがこういうものって覚えるしかなさそうですね
どうもありがとうございます
905 :
871 :2013/03/28(木) 13:02:51.85
>>904 CとPythonしか書いたことのないあっしですが、上の例を拝見するとPHPよりPythonの方がすっきりしてるように見えるなぁ....。
まぁ、慣れの問題なんでしょうけど....。
やたらとself連呼なのが嫌だってアンチの人は言うけど、どうなんでしょね? 少なくとも、あっしは気になりませんが。
http://pyyaml.org/wiki/PyYAMLにセットアップ方法が書かれているのですが PyYAML-3.10.zipをダウンロードしました
python setup.py install
python setup.py --with-libyaml install
ってやるとインストールようなんですが、たとえばPython3.3をアンインストールしたらpyyamlもアンインストールされるのですかね?
Pythonを入れなおした場合、またpyyamlはインストールしなおさないといけないのでしょうか?
909 :
デフォルトの名無しさん :2013/03/28(木) 14:34:54.21
>python setup.py --with-libyaml install >ってやるとインストールようなんですが、たとえばPython3.3をアンインストールしたらpyyamlもアンインストールされるのですかね? されない >Pythonを入れなおした場合、またpyyamlはインストールしなおさないといけないのでしょうか? しなおさないといけない
ありがとうございます
パーフェクトPythonを見ながらUbuntuにインストールしているのですが
$ apt-cache show python3 | grep 'Version'
$ sudo apt-get install python3.3 python3.3-dev
$ mkdir projects
$ cd projects
ここから先ができません。
$ pyvenv default
$ source default/bin/activate
$ wget
http://python-distribute.org/distribute_setup.py $ python distribute_setup.py
$ easy_install pip
>>911 書いてあるコマンドは実行できるよ
どこが出来ないのかわからないから人に伝える時の方法を教えよう
「このコマンドを打ったら」「こんなエラーが出ました」
「エラー内容:表示された英語全部(長い時は最初と最後の100文字くらい)」
CentOS6.4のpython2.6.6を使って、スクリプト内で__debug__の切り替えを行おうと思って、 #!/usr/bin/env PYTHONOPTIMIZE=1 python print __debug__ みたいなファイルを作って実行すると固まるし、 #!/usr/bin/env python -O print __debug__ みたいにすると「そのようなファイルやディレクトリはありません」と言われて動かない。 同じファイルを手元のMac(python2.7.3)で動かすと問題なく動くんだけど、なんででしょう?
自己レスです。 ググってたら、CentOSだと #! でのenvの引数は1つしか指定できないみたい。 原因は分かったけど、切り替えの解決法が分からない。 rubyだと #!/bin/sh exec ruby -x "$0" "$@" #!ruby puts 'Hello world!' みたいな記法があるみたいだけど・・・・
自己レスです #!/usr/bin/env bash ''''exec python -O -- "$0" ${1+"$@"} # ''' print __debug__ これで出来ました。
Python関係ないね
いや、シェルスクリプトとしてもPythonスクリプトとしても動くスクリプトになってる
918 :
911 :2013/03/30(土) 11:03:45.47
>>912 説明不足ですみません
pyvenv コマンドが見つかりませんとでました
調べたら
pyvenv-3.3 default
でできました。
python distribute_setup.py
をすると
/local/bin /local/libにインストールされるバグ?
http://bugs.python.org/issue16480 easy_install pip
パスがないためインストールできないようです。
>>918 コマンド打ってエラー出たらそのエラー書かないと
ubuntuならeasy_install使いたいなら
$ sudo apt-get install python-setuptools
920 :
918 :2013/04/02(火) 13:15:34.34
>>919 インストールしましたがpython3.3は未対応のようです。
ubuntuってpython3.2じゃない?3.3のパケジはPPAか何か?
Linuxはこの辺がやたらと面倒だねえ Windowsならインストーラ一個落として Wクリ一発で済むのに
linuxでもyumですぐじゃん
>>923 いやこの辺はWindowsのほうがよっぽど面倒。
>>925 インストーラWクリの
どこがどう面倒なのか説得力ある説明よろしく
>>926 ボタンのある位置までマウスポインタを動かして、そこからずれない様に
マウスを固定しつつ、すばやく二度もクリックしなければいけないのに
どこがどう面倒じゃないのか説得力のある説明よろしく
そもそも「パーフェクトPython」を買ってLinux使っている人 の質問じゃないという ここが超初心者スレであっても
インストーラのウィザードをクリックで進めなきゃいけないよ オプション選択もある
現にトラブってんだから大人しく窓使ってろって話
>>929 WindowsPCの一台くらい持ってるだろ?
やってみれよ。
Linuxは中でPythonが非常に重要な役割で動いてる よってデフォルトじゃないバージョンを入れるには注意しないと環境が壊れる WindowsはPythonがよそ者だから何をしても壊れない
本が意味も無くLinuxと3.3を薦めてんだろ 読んでないけど想像はつくな
パーフェクトPythonのLinuxの説明はめちゃくちゃ 良い子は真似すんなよ
気になるから立ち読みしてボロクソに批判しようかな
パーフェクトPythonは最後まで立ち読みしてきたけどクソ技術書だねこれ 読み終わった後レジの横にあったゴミ箱に捨ててきた
>>933 よそ者の在日民主が暴れても国は揺るがないが
自民が売国すると国が死ぬみたいなものだな
>>926 そもそもソフトごとのインストーラなんてものがない。
パッケージマネージャ使う。
新たにインスコしたければ、他のいろんなパッケージと同様にパッケージマネージャから
インスコしたいパッケージ選ぶだけ。
バージョンが上がればパッケージマネージャが他のパッケージと一緒にバージョンアップ
してくれる。
Lunixでpipやeasy_install使うのはパッケージマネージャの管理外になるので邪道。
>>933 使ったことない奴が何言ってんのよ。
パッケージリポジトリに登録されてるバージョンが最新じゃなかったりして 自分でビルドする羽目になるよね(´・ω・`)
941 :
デフォルトの名無しさん :2013/04/02(火) 22:54:48.43
Linuxは中でPythonが非常に重要な役割で動いてる よってデフォルトじゃないバージョンを入れるには注意しないと環境が壊れる 自分で使うバージョンは自分でビルドしたほうが安心
>>939 こいつ使ったことない絶対w
pipはpipでアップデートするんだよw
パケジなんてなくても.tar.gzからでもインスト出来るし管理出来るかどうかだろ?
何が邪道だw Linux使えてない人が言うでない
ディストロのリポジトリに入ってるのが古かったり Pythonのバージョン上げると問題が出てきたりするから 上の例ではvenvなんかで仮想環境を掘ってるんだろう と思うんだけど本の現物を見てみないとなんとも
後方互換性無くしたバカは切腹しろ
>>942 Linux使ったことないおまいさんには理解できない世界かもしれんけど、
Linuxではそのシステムにインストールされてるパッケージは全部パッケージマネージャが管理するのが前提なんだよ。
パッケージマネージャが各パッケージの依存関係も管理するから。
pythonのパッケージもディストリビューションのリポジトリに入ってるのをパッケージマネージャでインスコする。
その範囲であればディストリビューションが動作を確認してることを意味する。
それ以外の手段でインスコしたパッケージは自分で管理しなければならない。
UbuntuなりFedoraなり大体のディストリビューションはウェブからリポジトリのパッケージ検索できるから確認してみそ。
いやいや独自のパッケージマネージャを使ってるPython使っといてそれはちょっと…
例えばブラウザのアドオン・拡張機能・プラグインは 独自インストールですしお寿司
>>918 (default) $ python distribute_setup.py
がうまくいったとして、
(default) $ echo $PATH
(default) $ ls -l default/bin
(default) $ which easy_install
の入力と出力それぞれ貼ってみて
バグほったらかしのdebとか産廃だから処分してくれないとなあ
つかメンテナが飽きて保守されなくなりました通知がマジで欲しい
951 :
918 :2013/04/03(水) 09:36:07.17
>>948 $ echo $PATH
/home/ubuntu/projects/default/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games
$ ls -l default/bin
合計 8
-rw-r--r-- 1 ubuntu ubuntu 2150 3月 29 10:33 activate
-rwxr-xr-x 1 ubuntu ubuntu 121 3月 29 10:33 pydoc
lrwxrwxrwx 1 ubuntu ubuntu 9 3月 29 10:33 python -> python3.3
lrwxrwxrwx 1 ubuntu ubuntu 9 3月 29 10:33 python3 -> python3.3
lrwxrwxrwx 1 ubuntu ubuntu 18 3月 29 10:33 python3.3 -> /usr/bin/python3.3
$ which easy_install
/usr/local/bin/easy_install
>>951 $ source default/bin/activate して仮想環境が有効になった状態で
(default) $ python distribute_setup.py したのなら
easy_install は default/bin に入るんじゃないかと思う
というわけで仮想環境が有効になっていない状態で
$ python distribute_setup.py した可能性はない?
>>911 ,918,920,951
おっと先に回答があったようですが
Python3.3のvenvを試す
ttp://ymotongpoo.hatenablog.com/entry/2012/09/03/002604 $ pyvenv-3.3 default
このコマンドで default/ というディレクトリを作成し
default/ 以下のPython環境を3.3としている
ただこれ、このディレクトリに入ったら自動でその環境になるわけではなく
そこに作られた default/bin/activate を読み込むことでその環境になる
$ default/bin/activate を実行すると仮想環境(今回は3.3)になり
環境から抜けるには $ deactivate
簡単に理解するには以下のようにインタプリタを呼び出してみるとわかる
$ default/bin/activate
----------------------------------------
(default) $ python
----------------------------------------
Python 3.3.0
>>> exit()
(default) $ deactivate
----------------------------------------
$ python
----------------------------------------
Python 2.7.3
>>> exit()
>>953 bin/activate は直接実行ではなく source しなきゃいけない
というか直接実行できないようになってるはず
$ python -V Python 2.7.3 $
てかまだvirtualenv使ってる方がいい pysetupもまだだし
957 :
918 :2013/04/03(水) 14:10:35.24
>>952 ubuntuを再インストールして試してみましたが
/local/binにインストールされます。
コマンド
$ sudo apt-get install python3.3 python3.3-dev
$ mkdir projects
$ cd projects
$ pyvenv-3.3 default
$ source default/bin/activate
$ wget
http://python-distribute.org/distribute_setup.py $ python distribute_setup.py
>>957 source したらプロンプトの左側に (default) って出てない? 出てるなら端折らないで
出てる状態で su/sudo つけずに $ python distribute_setup.py して
/local/bin なんて場所に easy_install が入っちゃうのならお手上げ
959 :
918 :2013/04/03(水) 16:27:41.62
>>958 $ sudo apt-get install python3.3 python3.3-dev
$ mkdir projects
$ cd projects
$ pyvenv-3.3 default
$ source default/bin/activate
(default) $ wget
http://python-distribute.org/distribute_setup.py (default) $ python distribute_setup.py
easy_installは/local/binにインストールされます。
(default) $ ./default/local/bin/easy_install pip
pipも/local/binにインストールされます。
su/sudoしてないのにインストールできるわけないじゃん
>>959 /local/bin って ./local/bin のことか…
やっつけな回避策でいいなら bin/activate を開いて
PATH="$VIRTUAL_ENV/bin:$PATH"
PATH="$VIRTUAL_ENV/local/bin:$PATH"
とかすればとりあえず local/bin にパスは通る
962 :
918 :2013/04/04(木) 09:15:42.65
>>960 sudo すると
/usr/local/binに2.7がインストールされました。
>>961 説明不足ですみません。
pyvenvの状態では
(default) $
/home/ubuntu/projects/default/local/bin
にインストールされます。
$ pyvenv-3.3 --clear default
にすると環境全部消えるので書き換えたPATHも戻ってしまいますが
対策されるまでしばらくこれで使ってみます。
どうもありがとうございました。
sudo python3でやったか?
sudoしたらだめ。システムに影響が出ないようにvenvで仮想環境作ってるんだから
狙ったバージョンをOSにインスコするだけなのに 何日もかかるって… UNIX系OSの暗黒面が大爆発している例だな。
>>953 のサイトのやり方なら問題ない
バグというか仕様なんだから
ubuntu で distribute_setup.py 使わなければOK
.tar.gz 落として setup.py install
968 :
829 :2013/04/04(木) 20:39:35.04
クラスを要素に持ってたリストを消去するのに hoge=[]と del hoge[:]で挙動が異なるんだなぁ、奥が深い....。この数日ハマった...。
969 :
968 :2013/04/04(木) 20:41:04.90
↑すみません。829じゃないのに間違えました。
パッケージマネージャ使わないとか死ねよ ぷんすか
死ねよは言い過ぎじゃ
>>953 のサイト見た?
pyvenv でヴァーチャル環境でローカルにインスコ出来て
--clear できれいサッパリ削除出来るってお得じゃないか
いや随分パッケージ管理システムにご執心な奴がいたから 気持ちを代弁してやっただけよ
973 :
918 :2013/04/05(金) 09:52:58.94
>>973 python distribute_setup.py も結局 python setup.py install するのでそうなるだろう
ところで pip で入れたモジュールはちゃんと使えてる?
質問です ある文字列 ( 0-9 a-f A-F のみが含まれる) '123456789abcdeff0123456789abcdef' ... から [0x1234, 0x5678, 0x9abc, 0xdeff, 0x0123, 0x4567, 0x89ab, 0xcdef] ... という 2byte 毎の値のリストを得るにはどんな書き方がありますか? 文字列の長さは常に 8 の倍数ですが最大の長さは不明です(どこまでも大きくなる可能性あり)
どこまでも大きくなるってのは例えばSocketStreamがReadしないとデータがあるかどうか分からないような状況を言っているのか? それとも1024か32768か2^32か不明なだけで、処理するときには判明しているのか?
>>975 >>> s = '123456789abcdeff0123456789abcdef'
>>> [int(s[i:i+4], 16) for i in range(0, len(s), 4)]
[4660, 22136, 39612, 57087, 291, 17767, 35243, 52719]
>>> [hex(int(s[i:i+4], 16)) for i in range(0, len(s), 4)]
['0x1234', '0x5678', '0x9abc', '0xdeff', '0x123', '0x4567', '0x89ab', '0xcdef']
これでいいのかなあ。なんかやりたいこととは違う気がしなくもない
いや、そもそもPythonの文字列は長さが判明してないとおかしいから、 質問者が文字列から、と言っている以上、前者ではありえない。 ['0x'+s[i:i+4] for i in range(0,len(s),4)]
f = StringIO(s) [int(i, 16) for i in iter(lambda: f.read(4), '')]
import struct, binascii struct.unpack('>%dh' % (len(s) / 4), binascii.a2b_hex(s))
みなさんありがとうございます
stream から読むのをイメージしていました
>>979 さんのが一番良いみたいです
あとお願いついでですが
'123456789abcdeff0123456789abcdef' ...
から
[(0x1234, 0x5678), (0x9abc, 0xdeff), (0x0123, 0x4567), (0x89ab, 0xcdef)] ...
の様にペアにしたタプルで得るにはどう書けば良いですか?
[(int(i, 16),int(j, 16)) for i,j in iter(lambda: (f.read(4),f.read(4)), ('',''))]
import StringIO, struct, binascii s = '123456789abcdeff0123456789abcdef' f = StringIO.StringIO(s) [struct.unpack('>2h', binascii.a2b_hex(i)) for i in iter(lambda: f.read(8), '')] [(4660, 22136), (-25924, -8449), (291, 17767), (-30293, -12817)]
おつぱいそん
g = (int(i, 16) for i in iter(lambda: f.read(4), '')) # itertools レシピのgrouper list(itertools.izip_longest(*([g]*2), fillvalue=None))
int(i, 16) のところで符号付整数にするにはどうすればいい?
988 :
デフォルトの名無しさん :2013/04/07(日) 17:48:13.75
python3を積極的に導入する理由ってある? python2でできない、あるいは難しいこととかあるのかな
ちょっと訂正 int(i, 16) のところで16ビット符号付整数にするにはどうすればいい?
32767より大きいなら65536を引く
それでもいいんだけど int() になんか便利なオプションあるのかなと思って
pythonはCのscanfみたいなのとかないのかな。
Python には現在のところ、scanf()に相当するものがありません。 約 1,220 件 (0.39 秒)
正規表現で大概のことは出来るんじゃないかなと思う
2から3に乗り換える利点は何ですか?
デメリットはお前のような奴がいることです
scanfって正規表現使えたっけ
>>989 16bit目が1なら全bit反転して+1
1001 :
1001 :
Over 1000 Thread このスレッドは1000を超えました。 もう書けないので、新しいスレッドを立ててくださいです。。。