1 名前:デフォルトの名無しさん mailto:sage [2008/02/22(金) 01:27:53 ] Python オフィシャルサイト www.python.org/ 日本Pythonユーザ会 www.python.jp/Zope/ FrontPage - Pythonのお勉強 python.rdy.jp/ 前スレ pc11.2ch.net/test/read.cgi/tech/1201073019/l50 ◆関連スレッド Microsoft IronPython 1.0 pc11.2ch.net/test/read.cgi/tech/1157686822/ Python の宿題ここで答えます Part 1 pc11.2ch.net/test/read.cgi/tech/1153585095/ 2ch検索: [python] find.2ch.net/?BBS=ALL&TYPE=TITLE&STR=python ◆関連リンク Python 日本語ドキュメント - Pythonistaのお友達 www.python.jp/doc/release/ Pythonのバイブル的書籍 www.amazon.co.jp/dp/4797341815 その前編 www.amazon.co.jp/dp/4797341815
680 名前:674 mailto:sage [2008/03/15(土) 14:17:33 ] みなさんありがとう! Mac OS X と Windows をターゲットにした客先なので os.name 見て切り替えるしかないですね。 pywin32 でも ctypes でもいいから標準インストールに含まれるようにならないかなーと思ったら 2.5 から ctypes 入ってたのねorz 知らなんだ...
681 名前:636 mailto:sage [2008/03/15(土) 22:24:47 ] >>659 超ありがとう
682 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 00:01:51 ] win32com.clientを使いたいんだけど、 '\x83N\x83\x89\x83X\x95\xb6\x8e\x9a\x97\xf1\x82\xaa\x96\xb3\x8c\xf8\x82\xc5\x82\xb7' なんてエラーメッセージが帰ってきたんです。 これ、何て読むんですか?
683 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 00:03:52 ] >>> print '\x83N\x83\x89\x83X\x95\xb6\x8e\x9a\x97\xf1\x82\xaa\x96\xb3\x8c\xf8\x8 2\xc5\x82\xb7' クラス文字列が無効です 確かに見づらい罠。
684 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 00:36:41 ] >>683 シフトJIS? utf-8な環境だと????だらけで見れない。
685 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 01:14:11 ] だな。sjisにdecodeでおk。
686 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 02:10:23 ] 教えてください! PyDEVでプログラムを書いています。 書いたプログラムを実行するのに「次を実行ボタン」「ダイアログが開く」 「Python実行を選択する」「OKボタン」の順に操作するのが面倒です。 また、「左のツリーからファイルを右クリック」「右クリックメニュー」「実行→」「Python実行」 とメニューを辿っていくのも面倒です。 なんかボタン一発で今開いているファイルを実行する方法はありませんか?
687 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 02:13:01 ] 書いたpyファイルダブルクリックが最速かもな 端末から打つより早いだろうし
688 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 02:44:35 ] 左側のツリー(Pydevパッケージエクスプローラ)で、 開いているファイルをダブるクリックすると、一瞬マウスが砂時計になって、その後何も起こりません。 開いていないファイルをダブるクリックすると、エディタで開きます。 どこでダブルクリック?
689 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 08:16:44 ] 困ったことがあったら、 >>1 にリンクされている 聖書を読むべき
690 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 08:29:47 ] 聖書ってお民パイのことか?w
691 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 11:48:19 ] ITproにPythonの連載がのってた。 itpro.nikkeibp.co.jp/article/COLUMN/20080207/293301/ 2回目がSQLObjectだった。
692 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 11:50:43 ] 気軽といいつつLinuxを例にしてるアレか
693 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 11:54:01 ] SQLAlchemyだったら読みに行くんだが・・・
694 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 13:04:59 ] datetime.strptime に UnicodeString 渡したらエラーになった…。 str のまま渡すとうまくいく模様。これって変じゃないか? ---- # -*- coding: cp932 -*- from pprint import pprint from datetime import datetime # 成功 pprint( datetime.strptime("2008年3月16日 2:03", "%Y年%M月%d日 %H:%m") ) # 失敗 pprint( datetime.strptime("2008年3月16日 2:03".decode("cp932"), "%Y年%M月%d日 %H:%m".decode("cp932")) ) ----
695 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 13:37:00 ] datetime.datetime.strptimeがunicodeならsys.getdefaultencoding()でstrに変換、という処理を行ってるからのようだ。 time.strptimeはそんなことをしていないので、バグかな? $ python -S Python 2.5.2 (r252:60911, Mar 12 2008, 13:36:25) [GCC 4.2.3 (Ubuntu 4.2.3-2ubuntu4)] on linux2 >>> import sys, time, datetime >>> sys.getdefaultencoding() 'ascii' >>> time.strptime(u"2008年3月16日 2:03", u"%Y年%M月%d日 %H:%m") (2008, 3, 16, 2, 3, 0, 6, 76, -1) >>> datetime.datetime.strptime(u"2008年3月16日 2:03", u"%Y年%M月%d日 %H:%m") Traceback (most recent call last): File "<stdin>", line 1, in <module> UnicodeEncodeError: 'ascii' codec can't encode character u'\u5e74' in position 4: ordinal not in range(128) >>> sys.setdefaultencoding('utf-8') >>> sys.getdefaultencoding() 'utf-8' >>> time.strptime(u"2008年3月16日 2:03", u"%Y年%M月%d日 %H:%m") (2008, 3, 16, 2, 3, 0, 6, 76, -1) >>> datetime.datetime.strptime(u"2008年3月16日 2:03", u"%Y年%M月%d日 %H:%m") datetime.datetime(2008, 3, 16, 2, 3)
696 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 14:10:24 ] strptimeのメインの処理は_strptime.strptimeなんだけど、 これを呼ぶPyObject_CallMethodの第三引数formatが違うんだな。 datetime.datetime.strptimeは"ss"になってる(strへの変換)。 time.strptimeは"O"でタプルのまま渡してる。
697 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 16:38:50 ] >>691 SQLObjectのことをフレームワークと言ってて「ふーん」と思った。
698 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 22:48:46 ] >>686 Eclipse + Pydev? F11やCtrl + F11はどうよ
699 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 23:11:59 ] >>698 レスありがとう。 F11すると「次を実行ボタン」を押したときと同じでダイアログがでてきました。 >>686 で書いたのと同じです。Ctrl+F11は何も起こりません。 ソースをちょこちょこ変更して実行して、、、ていうことを繰り返してると、 実行するまでの動作がだんだん煩わしくなってきます。
700 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 23:48:22 ] どなたか教えてください t=urllib.urlopen("http://〜〜").read() print type(t) とするとstrとなるんですが。 utf-8のサイトの場合 tの型がunicodeになってほしいんです どうしたらよいでしょうか。 python2.5の場合はstrのままテキストに落としたらutf-8として文字化けせずに表示されるのですが ironpythonの場合テキストエディタで開いたらASCIIとして認識され文字化けされています。 utf-8としてそのファイルを保存し直しても文字化けしたままです。 解決策ご存じの方いましたらお願いします
701 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 23:52:27 ] t=urllib.urlopen("http://〜〜").read().decode("utf-8")
702 名前:デフォルトの名無しさん mailto:sage [2008/03/16(日) 23:58:58 ] >>700 入門書嫁。
703 名前:700 mailto:sage [2008/03/17(月) 00:39:43 ] 文字化けしない方法自己解決しました。すいません; ファイルの側をバイナリモードで開いて突っ込むだけでした。 open("hoge","wb")
704 名前:700 mailto:sage [2008/03/17(月) 02:02:00 ] >>701 ちゃんとレスが表示されてなくて見てませんでした。 それだとAsciiキャラクタじゃないから変換できませんよーってエラーがでます。 ironpythonではutf-8なんて定義されてないって出ました 僕の環境だけでしょうか・・・・?
705 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 10:23:43 ] >704 ところで Python のバージョンは?
706 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 11:14:09 ] また文字コードか
707 名前:デフォルトの名無しさん [2008/03/17(月) 11:45:17 ] 文字コードの諸問題もテンプラに入れて初心者が醤油と大根おろしで美味しく食せるようにするべき
708 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 12:33:53 ] pythonce mobileとpythonce smartphoneってどうちがうんですか?
709 名前:デフォルトの名無しさん [2008/03/17(月) 15:04:11 ] 正直文字コードをうまく扱えないやつはPython使うなといいたい。 Rubyのがはるかに先を行っている
710 名前:デフォルトの名無しさん [2008/03/17(月) 16:00:43 ] どう先を行っているの? 煽りじゃなくてマジで知りたい。 しかしRubyを学ぶのは断る!
711 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 16:11:21 ] ほんとどの言語使っても文字コード絡みはネックだなー Pythonに限った話しじゃないけど、文字コードの仕組みというか原理というかを完全に理解してる方たちは、 悩まずプログラミング出来てますか? なんかいっつも日本人可哀想だなーって思ってしまう俺がアホなだけ?? 一回とことん文字コードについて勉強したほうがいいんかなー
712 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 16:17:39 ] 文字列は基本unicode、strは単なるバイト列(≒I/O用) なんもややこしいことはない。
713 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 17:54:59 ] >>711 unicodeへのエンコードモジュールを自分で作ってみ。
714 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 18:14:19 ] u'ほげほげ' を勝手に UTF-8 だと思い込んでいるひとが意外と多い それがすべての間違いの元
715 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 19:07:39 ] >>> a="タ" >>> if a in "[ぁ-んァ-ン]": print "true" ... else: print "false" 文字列が、ひらがな、もしくはカタカナだと 判定するにはどうしたら良いですか? 上記のだとうまくいかない…
716 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 19:47:50 ] if a in [c for c in u'ぁ-んァ-ン']: print "true" else: print "false"
717 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 20:02:05 ] >>716 >>> for e in u"ぁ-ん": ... print e, ... ぁ - ん >>> for e in [c for c in u"ぁ-ん"]: ... print e ぁ - ん できないジャン
718 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 20:07:45 ] print re.match(ur"[ぁ-んァ-ン]", u"タ") is not None
719 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 20:09:33 ] >>> for i in unicode('あア亜', 'mbcs'): print unicodedata.name(i) HIRAGANA LETTER A KATAKANA LETTER A CJK UNIFIED IDEOGRAPH-4E9C
720 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 20:39:32 ] c = u'タ' if u'ぁ' <= c <= u'ん' or u'ァ' <= c <= u'ン': print "true" else: print "false"
721 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 21:20:48 ] 見た感じ、unicodedata使うのが綺麗っぽいかな。
722 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 21:24:56 ] >>707 おっと、いい天ぷらは塩だけでいけるぜ
723 名前:デフォルトの名無しさん mailto:sage [2008/03/17(月) 22:06:51 ] 手元のベンチマークだと一文字だと比較 : 正規表現 : unicodedata = 1 : 2 : 2.5くらい 複数文字の文字列だと長ければ長いほど正規表現が抜群に速い (PythonのループはCと比べてかなり遅い)
724 名前:デフォルトの名無しさん [2008/03/17(月) 22:33:13 ] py2exe を使った場合、完全にその exe ファイルだけで 動くのでしょうか。それとも何らかの DLL などが必要なんでしょうか。
725 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 02:03:06 ] DLLも一緒にパックされる
726 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 08:15:55 ] Python的ヒエラルキーは 汚いけど速い<<<綺麗 汚いけど速い>綺麗だけどかなり遅い だろ
727 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 13:55:08 ] www.python.org/dev/peps/pep-0361/ 2.6, 3.0の正式リリースは9/3予定だって
728 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 15:25:07 ] ひげぽんがPythonのネガティブキャンペーンしてる。 最も todo と fix meが多いプログラミング言語は Python かもしれない d.hatena.ne.jp/higepon/20080317/1205768303
729 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 16:06:56 ] ToDoが明確になっているのはよいことじゃないかな? 何もないままいい加減なコードを書かれるよりずっとまし。 Pythonの人って被害妄想が強すぎる。だからいじめられるんだよ。
730 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 16:19:40 ] >>729 同意。ネガキャンというほどの内容でもないよね。
731 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 18:53:31 ] >>729-730 そうか。社内のPythonハッカーと抗争を始めたのかと早とちりして しまったよ。
732 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 19:01:10 ] >>731 西尾さんとは仲いいしそんなことはないっしょ
733 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 19:05:52 ] >>728 どう見てもなんとなく書いてみました風の記事なんですが
734 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 19:51:59 ] 早とちりしたのは西尾さん本人説。
735 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 19:53:26 ] >>729 TODOは 現時点ではこのコードは書けない 余裕のある時にやろう 汚いコードを書いていることに対する言い訳 と書いてますよ
736 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 19:56:14 ] 負け犬意識で頭がいっぱいのPython使いに栄光あれ!
737 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 20:02:41 ] こんなネタでしか盛り上がれないPythonスレの住人はバカだな。 PHPに帰れよ。
738 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 20:13:11 ] いやいや、Pythonにネガティブだったり無視したりけしからんと 言う奴は、頭でっかちで使えない人とか老害の域に達した技術者に 多いので、Pythonに対する態度でその技術者の成長の余地が測れ るのよ。
739 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 20:49:51 ] いやいや、PHPにネガティブだったり無視したりけしからんと 言う奴は、頭でっかちで使えない人とか老害の域に達した技術者に 多いので、PHPに対する態度でその技術者の成長の余地が測れ るのよ。
740 名前:デフォルトの名無しさん [2008/03/18(火) 20:59:36 ] ToDoって書いてあったらだめって? あふぉですか?こいつは。
741 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 21:12:02 ] 誰もだめとは言っていないとおもいますが あふ(ry
742 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 21:21:22 ] >>740 にしおさんにそんなこといってはいけませ〜ん!
743 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 21:23:01 ] 質問 list=[('apple', 1),('banana',2),('orange',3)] タプルの一番目の要素をキーにして ソートするにはどうしたら良いでしょうか?
744 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 21:26:01 ] list.sort() でいいじゃん
745 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 21:31:59 ] listという名前の変数に代入するなと(ry 汎用的なやり方としては(タプルの二番目の要素でソートする例) L=[('apple', 3),('banana',2),('orange',1)] L.sort(key=lambda x: x[1])
746 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 21:32:28 ] >>743 ここ辺りが参考になるかも ttp://morchin.sakura.ne.jp/effective_python/sort.html
747 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 21:39:41 ] 743みたいなネタで引っかかるやつ、いるよな。 基本的なところで引っかかって先に進めないようなやつは、 フレームワークを使いこなせるようになるまで、100年くらいかかったりするのだろうか。
748 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 22:35:12 ] 作り直した方がマシというフレームワークに こと欠かさないだろ。
749 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 22:40:15 ] >>715-717 そもそも、ぁ-んァ-ンはただの文字列。
750 名前:749 mailto:sage [2008/03/18(火) 22:41:32 ] スマソ。途中で書き込んじゃった。 >>715-717 そもそも、ぁ-んァ-ンはただの文字列。 unicodeの平仮名と片仮名全部出力できれば・・・・・・
751 名前:749 mailto:sage [2008/03/18(火) 22:44:03 ] >>743 .soat()に第一引数として、関数を与えるとその関数で判定を行います。 判定用関数には二つの引数が渡されるので、 def S:
752 名前:751 mailto:sage [2008/03/18(火) 22:45:38 ] またやっちまったorz インデントの習慣で・・・・・・ .soat()に第一引数として、関数を与えるとその関数で判定を行います。 判定用関数には二つの引数が渡されるので、 def S(A,B): return cmp(A[1],B[1]) とすればおk
753 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 22:48:21 ] Sorting Mini-HOWTO (和訳) ttp://www.python.jp/Zope/articles/tips/sorthowto 関数を渡すって言うのがピンとこなかったら ここでわかるようになるまで頑張っておく価値あり
754 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 22:59:32 ] >>751-753 この方法は旧式。遅い。 >>745-746 こっちが新式。早い。 つうか新式紹介した後に旧式を紹介してるやつはなんなの?
755 名前:753 mailto:sage [2008/03/18(火) 23:19:38 ] 不勉強でした。許して
756 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 23:24:14 ] >>745 の状況ではlambda使うよりはoperator.itemgetter(1)が好きだな
757 名前:デフォルトの名無しさん mailto:sage [2008/03/18(火) 23:55:07 ] ttp://www.python.org/dev/peps/pep-0361/ 2.6 と 3.0 は同時リリースなのか
758 名前:sort ⇒ 整列 mailto:sage [2008/03/19(水) 09:14:15 ] soat() ってナニ?
759 名前:751 mailto:sage [2008/03/19(水) 09:28:55 ] >>758 sort()だとおもわれ
760 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 09:59:55 ] >>749-750 for k in range(0x3040, 0x3100): try: print '%04x, %c' % (k, unichr(k)) except: print '%04x, None' % k
761 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 11:15:10 ] こんな関数を作ったらどうだろう def expand_char(s): i = 0 _chr = unichr if type(s) is unicode else chr _len = len(s) while i < _len: if s[i] == '\\': yield s[i+1] i += 2 elif i + 2 < _len and s[i+1] == '-': for j in xrange(ord(s[i]), ord(s[i+2])+1): yield _chr(j) i += 3 else: yield s[i] i += 1 for i in expand_char(u'ぁ-ん'): print '%x: %s' % (ord(i), i)
762 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 13:42:50 ] type() is じゃなくて isinstance 使えっていつも言ってんだろ 素直に unicodedata 使えよ
763 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 13:55:04 ] >>762 なんぞそれ
764 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 13:58:06 ] ininstanceのほうがいいね。しばらく使ってないと忘れるなあ
765 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 17:57:01 ] isinstanceなら継承関係も考慮してくれるしな
766 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 18:35:41 ] 「入門書も読めないゆとりが集まるスレ」に名前を変更した方がいいな
767 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 19:33:39 ] 「煽り一行書くだけしかできない生産性の無いゆとりが集まるスレ」に名前変えたほうがいいな
768 名前:デフォルトの名無しさん [2008/03/19(水) 19:43:08 ] 人間の頭なんて大差ないんだよ。 やるか、やらないか、それだけの違い。 毎日少しずつでも前進してる奴と、 毎日言い訳を考えて何もしない奴とでは差がついて当然。 たいしたことを思いつこうが、思いつくまいがそんなのどうでもいい。 出来ない奴を馬鹿にする奴はどうせたいした事無いから。 出来ない奴に対して自慢したいだけなんだよ。 やりたい事、目標を見つけて少しでも前進する事。 覚える事がさしあたって100あるなら1つずつ覚えていけばいいだけじゃないか。 一度に100覚えられないから漏れは駄目なんだと思ってるんじゃないのか? それは天才がやる事であって、凡人は1つずつやっていけば良いんだよ。 努力する癖を習得するんだ。
769 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:06:14 ] 挫折なんかしたことないなあ。分からなくなったことはあるが 色々試したりしてずっとやってたら分かったし。 挫折したとか言ってる人は自分で勝手に挫折したと決めている だけなのでは? 分かるまでずっとやってりゃそのうち分かるよ。 諦めなきゃ良いだけ。 いつまで経ってもできないという場合は本当は自分のやりたく ないことなのかも知れないけどな。そういう場合はやめてみれば いい。だがそれを「挫折」と呼んではいけない。それは単に やめただけだ。
770 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:19:24 ] FizzBuzz問題 1から100までの数字を出力する。ただし、 3の倍数のときは数字のかわりにFizz 5の倍数のときは数字のかわりにBuzz 15の倍数のときは、FizzBuzzと出力する。 これはここの人にはどう捉えられるのかちょっと知りたいな。
771 名前:デフォルトの名無しさん [2008/03/19(水) 20:21:38 ] >>770 それ、問題か? hello, world と同じレベルじゃねえか。
772 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:21:43 ] >>770 ガイシュツ
773 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:24:04 ] >>768 1%の才能と99%の努力が大切なのですが その1%の才能すら持ち合わせていない人が大勢います あなたもそのうちのひとりであることはほぼ間違いありません
774 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:25:11 ] >>770 簡単すぎて素直な回答を出したら低能だと言われそうで怖い問題。 出題者がビット演算とかトリッキーな回答を要求してるのではないかと 勘繰ってドツボにはまる。
775 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:26:28 ] 普通に書いたあとググっていかに短くできるか考え続けるだけ
776 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:28:43 ] >>774 有名なプログラマーもどき除け問題だけどタイプ可能な文字数の制限があったり十進じゃなかったりすると面白いのかな
777 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:38:58 ] コード書くのが好きで飯もいらないときがある、 別にこれで食っていこうとかは思わないけど趣味の範疇ならほんと楽しい。 素人だし下手糞なりに人に教えもしたけど、大体の奴は途中で飽きてやめていく。 そういう奴らは、読解力とか理解力なんかが足りないというか、 自分で調べる気がないというか。 別に馬鹿にしてるわけじゃないけど、そういうこと好きじゃないなら 無理してプログラムなんてやらなくてもいいんじゃないかな?
778 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 20:48:30 ] プログラミングって、実行させてはエラー出して、その度に調べて、って 根気良く続けるのが重要だと思う。 ちょっと上達してきて、エラー出すのが恐くなって、実行させるのが 億劫になったとき、成長が少し止まった気がした。 「とにかくやってみる」ことは武器の一つだと、小学校のときの先生が言っていた。 何つーか、動くコードを知るだけじゃなくて、動かないコードを知ることも 実は重要なんだよな。 要はエラーを恐れるなってこと。
779 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 21:11:10 ] なんでID出ないんだろうこの板
780 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 21:13:05 ] 人間だもの 人間だもの 人間だもの へびお
781 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 21:49:38 ] [[i,'Fizz','Buzz','FizzBuzz\n'][[3,0,0,1,0,2,1,0,0,1,2,0,1,0,0][i%15]]for i in xrange(1,101)]
782 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 21:54:01 ] for n in [[i,'Fizz','Buzz','FizzBuzz\n'][[3,0,0,1,0,2,1,0,0,1,2,0,1,0,0][i%15]]for i in xrange(1,101)]: print n,
783 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 21:57:15 ] print open("answer.txt").read()
784 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 22:02:51 ] for i in range(100):print i%3/2*"Fizz"+i%5/4*"Buzz"or-~i
785 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 22:04:16 ] python -c "__import__('webbrowser').open('www.google.com/search?q=python+fizzbuzz&btnI=I%27m+Feeling+Lucky ')"
786 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 22:49:43 ] 「入門書を読めない文盲のゆとりがポエムを貼り付けるスレ」に変更しませんか?
787 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 22:50:29 ] アンチスレと交換するだけでいいと思うよ
788 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 22:56:35 ] 早く恥パイの第3版の和訳だせボケ もう2.6出てんのに。
789 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 23:03:21 ] >>788 だから出ないんだって。 ソースな↓ ttp://tinyurl.com/23y5e
790 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 23:06:42 ] >>770 応用編 「3の倍数と3の付く数字だけアホになり、8の倍数だけ気持ち良くなります」
791 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 23:10:57 ] >>789 これは信頼できるソースだな
792 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 23:16:23 ] >>790 俺も言おうと思っていたが先越された
793 名前:デフォルトの名無しさん mailto:sage [2008/03/19(水) 23:18:58 ] >>> import urllib2 >>> urllib2.urlopen("tinyurl.com/23y5e ").url 'www.bulldog.co.jp/ '
794 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 01:01:25 ] >>792 やっぱり '3' in str(i) がキホン?
795 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 07:51:38 ] FizzBuzz問題って色んなバージョンあるんだね ttp://ja.wikipedia.org/wiki/%E6%B8%A1%E8%BE%BA%E9%90%98
796 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 11:57:56 ] 問題をアレンジして 3の倍数および3がつく時、アホになる に変えてみると?
797 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 12:24:06 ] for i in range(100):print (i%3/2or(-~i/10==3)or(-~i%10==3))*'Aho'or-~i
798 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 12:28:04 ] -~i何度も使うならこっちの方が短いね for i in range(1,101):print (i%3==0or(i/10==3)or(i%10==3))*'Aho'or i
799 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 12:40:04 ] しね
800 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 14:14:31 ] x%y==0 は、x%y<1の方が短い あと、(i/10==3)or(i%10==3)だったら'3'in`i`が短い
801 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 14:20:56 ] for i in range(1,101):print(i%3<1or'3'in`i`)*'Aho'or i
802 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 14:23:20 ] for i in range(100):print(i%3/2or'3'in`-~i`)*'Aho'or-~i
803 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 15:10:14 ] ('3'in`-~i`) == ('3'in`~i`)
804 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 16:02:03 ] くだらね
805 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 16:06:33 ] strと``ってどう違うの? 測ると``の方がだいぶ速いみたいだけど。
806 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 16:27:25 ] UNARY_CONVERT と CALL_FUNCTION
807 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 16:32:14 ] strじゃなくてreprだな
808 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 16:57:31 ] str は、そのオブジェクトを表す適当な文字列 repr は、そのオブジェクトを表すpython 式 >>> `'a'` "'a'" >>> str('a') 'a' >>> `2**32` '4294967296L' >>> str(2**32) '4294967296'
809 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 18:48:30 ] >>> [u'ほげ',u'ふが'] [u'\u307b\u3052', u'\u3075\u304c'] >>> `[u'ほげ',u'ふが']` "[u'\\u307b\\u3052', u'\\u3075\\u304c']" >>> `[u'ほげ',u'ふが']`.decode('unicode-escape') u"[u'\u307b\u3052', u'\u3075\u304c']" >>> print `[u'ほげ',u'ふが']`.decode('unicode-escape') [u'ほげ', u'ふが'] 各行の動作の違いを教えてください
810 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 19:19:51 ] >>807 >>808 なる、reprと同じだったね。 にしても不思議、何度測ってもrep()より``のが速い。
811 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 19:54:57 ] >>810 速度は>>806 が書いてあるように `` が UNARY_CONVERT のバイトコードだけになるから
812 名前:デフォルトの名無しさん [2008/03/20(木) 20:23:06 ] IDLEって完全にPython自身で書かれているのか・・・ ってことは自分のプログラムの途中から IDLE を起動するなんてこともできるのか?
813 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 20:57:48 ] import wx app = wx.PySimpleApp(0) frame = wx.Frame(None, -1, "Hello wxPython World!") app.SetTopWindow(frame) frame.Show(True) app.MainLoop() > AttributeError: 'module' object has no attribute 'PySimpleApp' 環境ubuntu7.10。wxPythonは入れたが上のエラーが出る。なぜ?
814 名前:デフォルトの名無しさん mailto:sage [2008/03/20(木) 21:02:57 ] 他にwx.pyがあるんじゃないか?そのスクリプト自体がwx.pyとか
815 名前:813 mailto:sage [2008/03/20(木) 21:05:27 ] うわ本当だ。。。 その通りです。ありがとう。>>814
816 名前:デフォルトの名無しさん mailto:sage [2008/03/21(金) 01:58:54 ] >>811 へー、バイトコードなんて調べた事無かったから>>806 は意味不明でしたw ようするに最終的にreprを呼ぶコードが出来るんだけど、 ``から出来たコードの方が速く処理が終わるのかな。
817 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 01:10:27 ] wxWidgets にはさ、GUI を XML で記述するってのがあるじゃん。あれと同じ理屈で Tk を YAML で記述するってのは無いかね。。。。yaml がなければせめて XML で。最初は自力で簡単なコーディングしてて gui_yaml = """ frame1(Frame): text: "Hello tk!" button1(Button): text: Exit command: quit """ て感じの yaml 形式テキストをつくって import yaml dict_ = yaml.load(gui_yaml) すると、 {"frame1(Frame)": { "text": "Hello tk!", "button1(Button)": { "text": "Exit", "command": "quit" }}} ていう辞書になるので、これを適当に解析して name(base_class) という項目を見つけたら指定されたクラスインスタンスを生成して、 command って項目があったら値に対応するメソッドを関連づけて… みたいな感じで Tk GUI を構築しようとしたんだけど、辞書だと順番が保存されないんで、コントロールを生成する順番に依存する処理の場合に死ぬる事に気づいた。 packするとき、どの順番で pack する?とか。grid 使えば順番非依存になるのかも。 というわけで自分でつくるのあきらめたので、できあいのやつ教えてください。
818 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 01:19:17 ] もしマトモに yaml -> Tk ビルダ作ったら、みんな使ってくれるかい?
819 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 01:24:56 ] なんで今更Tkにこだわるのさ
820 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 01:35:39 ] だって標準ライブラリにくみこまれてるじゃん
821 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 01:46:29 ] 辞書にorder項目を追加するだけじゃね?
822 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 02:13:48 ] 順番を保存するならシーケンスにするしかないよね。 てか辞書じゃ重複できないから、その例ちと変な気が。 Tkだととても軽いというのなら意味は有ると思う。
823 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 02:56:18 ] import yaml # PyYAML from pyyaml.org/wiki/PyYAML import Tkinter import re def build(parent, dic, commands): widget = None for key, val in dic.items(): o = re.match(r"(?P<name>\w+)\((?P<base>\w+)\)", key) if o: name, base = o.group("name", "base") klass = getattr(Tkinter, base) widget = klass(parent) #widget.pack() if parent: setattr(parent, name, widget) if isinstance(val, dict): build(widget, val, commands) elif key == "command": parent["command"] = commands[val] elif key == "pack": parent.pack(**val) if isinstance(val, dict) else parent.pack() elif key == "grid": parent.grid(**val) if isinstance(val, dict) else parent.grid() else: parent[key] = val return widget
824 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 02:59:55 ] # テストコード if __name__ == "__main__": gui_dict = yaml.load(""" frame(Frame): button1(Button): grid: {column: 1, row: 2} text: OK button2(Button): grid: {column: 2, row: 2} text: Cancel ent1(Entry): grid: {column: 1, row: 1} ent2(Entry): grid: {column: 2, row: 1} memo1(Text): grid: """) commands = {} app = build(None, gui_dict, commands) app.mainloop()
825 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 03:03:13 ] 823-824をそのまま貼付けて実行してください。 Entry の textvariable の扱いをどうすればよいかがさっぱり思いつかん。 一貫性を持たせるという意味で "text" でアクセスできればいいんだけど。
826 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 03:35:59 ] 標準にこだわってるくせに pickle使わずにYAML使う愚
827 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 03:52:49 ] だって xml より yaml のほうが編集しやすいじゃん。 まあ、たしかに yaml 表現が python の辞書リテラルとほとんど同じだから、 まんま python 式で書いてもいいんじゃ?と思ったのは事実。 だけど文字列を "" で囲まなくて良いのは地味に楽。
828 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 03:55:20 ] class TestClass(object): def __init__(self, i_name): _name = i_name def __eq__(self, i_other): if not isinstance(i_other, TestClass): return False return self._name == i_other._name a_key = TestClass('test') a_dic = {} a_dic[a_key] = 0 --------------------------------------------------- 上のソースコードをPython 2.5.2で実行すると問題ないけど、 Python 2.6a1で実行すると、最後の行でエラーがでたよ。 TypeError: unhashable type: 'TestClass' Python 2.6以降だと、object.__hash__()は実装されてないものなん?
829 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 04:06:37 ] >>827 それならさ、 wxPythonのXRCedが吐き出すXMLをYAML化してよ
830 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 04:11:50 ] >>823 GJ!! インデント崩れてない?
831 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 04:46:11 ] # インデント修正+コメント加筆 def build(parent, dic, commands): widget = None for key, val in dic.items(): o = re.match(r"(?P<name>\w+)\((?P<base>\w+)\)", key) if o: # name(base_class_name) にマッチした場合は新規にウィジェット生成する name, base = o.group("name", "base") # 名前とクラス名を取り出す widget = getattr(Tkinter, base)(parent) # ウィジェット生成 if parent: setattr(parent, name, widget) # 親の属性としてウィジェットを追加 if isinstance(val, dict): build(widget, val, commands) # ウィジェットの設定 elif key == "command": parent["command"] = commands[val] # 呼び出し可能なオブジェクトをコマンドに指定 elif key == "pack": parent.pack(**val) if isinstance(val, dict) else parent.pack() elif key == "grid": parent.grid(**val) if isinstance(val, dict) else parent.grid() else: parent[key] = val return widget # 最後に生成したウィジェットを返す
832 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 04:50:23 ] # テストコード gui_dict = yaml.load(""" frame(Frame): button1(Button): grid: {column: 1, row: 2} text: OK button2(Button): grid: {column: 2, row: 2} text: Cancel ent1(Entry): grid: {column: 1, row: 1} ent2(Entry): grid: {column: 2, row: 1} memo1(Text): grid: """) commands = {} app = build(None, gui_dict, commands) app.mainloop()
833 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 20:58:33 ] このまま進歩してって、数日したらちょっとしたフレームワークが出来上がってそうだ。
834 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 23:40:58 ] ____ / \ / ─ ─ \ / (●) (●) \ ない ない | (__人__) | \ ` ⌒´ ,/ r、 r、/ ヘ ヽヾ 三 |:l1 ヽ \>ヽ/ |` } | | ヘ lノ `'ソ | | /´ / |. | \. ィ | | | | |
835 名前:デフォルトの名無しさん mailto:sage [2008/03/22(土) 23:42:14 ] 思いつきだけで始めたことはたいてい早晩ポシャる 失敗するのはいいのだが、問題なのは、 一度や二度の失敗で学ばない人間がいかに多いかということだ
836 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 00:10:21 ] Pythonを選んだこと自体が失敗だからなぁ
837 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 00:13:51 ] 歴史から学べるのはただ一つ、 人は歴史から学ばないということだけ だとばっちゃが言ってた
838 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 01:22:16 ] つまり韓国に関わっていたら日本は不幸になるってことですね! さすがばっちゃ!頭いいや!
839 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 01:47:02 ] >>835 一度や二度の失敗で投げてたら何も作れんぞ。 大事なのは、捨てて作り直す勇気だ。
840 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 03:04:52 ] 自作してる時点でTkの負けだと思いました>< xml使ってないけど。
841 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 03:22:33 ] 出来あがった物が思いの外ショボいと モチベーションが続かないんだよなぁ
842 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 03:33:50 ] >>837 φ(..。 )メモシテオコウ
843 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 03:40:18 ] こういうのは衝動が肝心だと思うんだ。 ガーッと書いて結局没になる、そういう自己満足って大事よ。 あんまりはまるとPC恐怖症になるけど。
844 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 07:13:06 ] 何度やっても同じだよ。 そもそもセンスがないんだから。一生ドカタ暮らし。
845 名前:デフォルトの名無しさん [2008/03/23(日) 09:23:21 ] 一生ドカタできるならまだいいさ。 俺なんかすら干されそうだ。 マァ無能だから仕方ない。 結構なんてするんじゃなかった。 自殺すらできない。保険増額しておこう。
846 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 11:28:05 ] なんだこの流れ
847 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 11:39:22 ] 流れなのかこれは。
848 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 12:50:59 ] 春は色々湧く季節
849 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 13:28:31 ] PythonにRubyのPathnameみたいなクラスってないですか? os.path.hoge(path); os.path.huga(path)が面倒なので p = Path(path)などとしておいて p.hoge(); p.huga()とできるような感じのものでいいんですが… 自分でつくるしかないですかね?
850 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 13:37:35 ] よく意味が分からんがimport os.path as pって意味ではなくて? 別にimport os.pathしてからp = os.pathでもいいけど。
851 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 13:47:44 ] すまん。Rubyしらんのに適当いうもんじゃなかった
852 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 13:57:32 ] >>849 標準ではないけど ttp://www.jorendorff.com/articles/python/path/ とか
853 名前:849 mailto:sage [2008/03/23(日) 14:19:38 ] >>850 >>852 いろいろ検索しても見つからなかったのでないのかと思っていましたが あるんですね。探し方が悪かっただけで。ありがとうございます!
854 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 14:27:19 ] >>853 今後もPythonと付き合っていくなら可能な限り標準モジュールを利用した方がいいよ
855 名前:850,851 mailto:sage [2008/03/23(日) 14:46:12 ] >>853 いや、俺のは違うから。スマン。 RubyのPathnameオブジェクトってのを知らなかったんで 勘違いしたんだよ。
856 名前:849 mailto:sage [2008/03/23(日) 15:07:30 ] >>854 そういうものなんですかね? os.pathは使うとき逐一引数にパス名指定しないといけないので面倒なんですよね… >>852 さんに紹介していただいたようなクラスが標準に入ればいいのですが >>855 ああ、すいません。書き方が悪かったみたいです >>855 さんの回答は今回はちょっと希望に沿うものではなかったのですが 質問したときは回答していただいた方全員にお礼を言いたいと思っているので…
857 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 18:13:25 ] 「できるだけ標準モジュールを使え」はGuideの言葉だっけ?
858 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 19:29:53 ] >>849 os.stat()を使えば解決しそうだけど
859 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 20:17:05 ] lambdaで逃げるって手も...ないか。
860 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 21:26:23 ] Guideって誰? それどんな道案内?
861 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 22:15:43 ] >>860 かわいそうなPython使いを ジョセフ様に認められた清く正しい言語Rubyへの 改宗を促すGuideです。 Pythonを作られたGuidoさんとは別です。
862 名前:デフォルトの名無しさん mailto:sage [2008/03/23(日) 22:20:26 ] カルト言語逝ってよし。
863 名前:デフォルトの名無しさん mailto:sage [2008/03/24(月) 11:42:31 ] ruby使いは正確悪いことで有名
864 名前:デフォルトの名無しさん mailto:sage [2008/03/24(月) 13:56:51 ] お前の性格の悪さも分かった
865 名前:デフォルトの名無しさん mailto:sage [2008/03/24(月) 14:33:40 ] >>863 たまには変換候補のことも思い出してあげてください。
866 名前:デフォルトの名無しさん mailto:sage [2008/03/24(月) 14:37:14 ] pythonで数値計算はnumpyだけど数式処理は何かあるの?
867 名前:デフォルトの名無しさん mailto:sage [2008/03/24(月) 17:54:39 ] しらない
868 名前:デフォルトの名無しさん mailto:sage [2008/03/24(月) 19:00:16 ] 他人を敬えない人は、他人から敬われることはありません。 日本語が不自由ならなおさら。 良くて一生ドカタ。 たいていはいい年になってから路頭に迷う。 本当にありがとうございました。
869 名前:デフォルトの名無しさん mailto:sage [2008/03/24(月) 19:10:30 ] 経験者の話は説得力がありますね
870 名前:デフォルトの名無しさん [2008/03/24(月) 23:36:43 ] なんといつのまにか wxVCLなるものがあるみたいじゃないか。VCLの使い勝手が忘れられない俺がまちのぞんだもの。 だれかpythonバインディング作って
871 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 02:20:38 ] C++スレにも書いたけど、こっちにもネタ投下してみる。 なるべく短いプログラム書いてみようぜ。 基本問題: 例えば N = 8 としたときに 「この文章には0が1個、1が5個、2が3個、3が2個、 4が1個、5が2個、6が1個、7が1個含まれています」 という文章が生成されるとして、9以下の任意の自然数Nについて もこのような文章を生成するプログラムを作れ。 解がない場合は「解なし」とする。 発展問題: Nが10以上の時、解はあるだろうか?
872 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 02:28:43 ] 一応自分の答え(うろ覚え)さらしとく X = 8 S = ["" for i in range(X)] found = False def count(num): ret = 0 for i in S: ret += i.count(str(num)) return ret def check(): for i in range(X): if count(i)+1 != int(s[i]): return found = True print "数字の数は", [str(i)+"が"+str(s[i])+"個" for i in range(X)] def find(depth): if depth < 0: check() else: for i in range(X): s[depth] = i find(depth - 1) if not found: print "解なし" print "終了" find(X-1)
873 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 02:47:48 ] ごめん、問題の意味がわからない
874 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 02:53:15 ] 短くしようとしたら総当りになると思う。 それよりもスマートな解き方を探すほうが面白そうだな
875 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 02:58:37 ] >発展問題: >Nが10以上の時、解はあるだろうか? 10がn個あります、と言った時の意味がわからない
876 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 03:01:55 ] どっかの課題丸投げ乙
877 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 03:07:32 ] 変数Nは「」内に影響しないため、Nがどのような値でも 「この文章には0が1個、1が5個、2が3個、3が2個、 4が1個、5が2個、6が1個、7が1個含まれています」 という文章が生成されます。
878 名前:871 mailto:sage [2008/03/25(火) 03:19:09 ] 丸投げじゃないよ。今日仕事中に思いついた問題。 ちなみにNが4のときの解。ようするに N 以上の数を使わない。 「0が1個、1が2個、2が3個、3が2個」 Nが10のときは "10" という部分文字列がいくつ含まれるかって解釈にしようと思う。
879 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 03:57:45 ] 0-2 1-8 2-3 3-3 4-1 5-1 6-1 7-1 8-2 9-1 10-1
880 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 09:57:56 ] ドウカクカクカク。
881 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 10:34:00 ] ブラック民パイ読んで、練習でHP作ってるんだけどさあ・・・・HTMLのテンプレートを簡単につくるソフトでいいのってないの? ホームページビルダー(バージョンふるいのしか持ってない)で作って、置き換え文字を書き加えるとかじゃ・・・・ちょっと使いづらいぜ。
882 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 10:43:31 ] >>881 HTMLかくんだったら、テキストエディタでおk。 入力補助がついてるのもあるし、なんだったらメモ帳やワードパッドでもいける。
883 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 11:31:43 ] >>871 が基地外にしか見えない
884 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 11:41:05 ] >881 Nvu nvudev.com/
885 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 11:42:58 ] >>883 >>871 が見えるおまえは基地外認定
886 名前:866 mailto:sage [2008/03/25(火) 12:03:30 ] >>866-867 ないのならmaximaのあるcommon lispに乗り換えを決意した
887 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 13:45:09 ] お昼に見てからやっと >>871 の意味が分かったわ ちょっと仕事の合間に考えて見るか
888 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 19:05:30 ] >>871 をN<=10(二桁にならない)までで高速化してみた codepad.org/m5o71GS1
889 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 20:54:01 ] C++は老害言語。
890 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 22:00:41 ] >>884 Nvuは開発止まってるから後継ソフトにしようね KompoZer: kompozer.net/
891 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 23:21:00 ] 回転座標求めるのに def rot(x, y, radian): c = math.cos(radian) s = math.sin(radian) return x*c - y*s, x*s + y*c と def rot(x, y, radian): return math.hypot(x, y) * cmath.exp(radian*1j) の速度を比べてみると、明らかに複素数使った方が速い。。。が X, Y成分を取り出す処理を入れると結局始めから三角関数使った方が速い。なんかくやしい。
892 名前:デフォルトの名無しさん mailto:sage [2008/03/25(火) 23:48:33 ] x,yはc.real と c.imag で取り出してる?
893 名前:891 mailto:sage [2008/03/26(水) 00:16:01 ] >>892 ttp://codepad.org/e53Ole56 あれ? デスクトップでやった時と結果が違う。。。。
894 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 03:32:48 ] rpy.sourceforge.net/ Rをpythonから呼べる 便利そうだがnumpyで直接計算するのと比べてどうなんだ
895 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 03:38:08 ] modular.math.washington.edu/sage/ pythonの数式処理っぽいのあった
896 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 03:44:09 ] python -> sage -> maxima -> common lisp でcommon lispをpythonから呼べるね もっと単純な方法ありそうな気もするけど
897 名前:デフォルトの名無しさん [2008/03/26(水) 10:45:12 ] py2exe 使うと使っている標準モジュールが自動的に 同梱されますが、これも丸ごと配布してしまっていいん でしょうか?というか、py2exe で実行ファイル形式にして 配布するときってライセンス的にどんな制約があるんでしょう? 自分が作ったプログラムも含めてPSFに従わないとだめ?
898 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 13:25:01 ] PSFはGPLじゃないのでちゃんとPythonの著作者表示があれば自由だったはず
899 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 14:22:28 ] PSFはライセンスじゃない。 それはそれとして、っ ttp://www.python.jp/pipermail/python-ml-jp/2007-May/004044.html
900 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 14:31:13 ] >>894 ・統計屋の中で流行っている統計手法はいち早くRで誰か実装するので、 自分で書き直す手間は省ける。 ・Rになれている人に使いやすい。 ・グラフなんかをプロットするとよく落ちる。 ってところかな。
901 名前:デフォルトの名無しさん [2008/03/26(水) 15:45:42 ] すまんが、cgiのGETとPOSTって両方一度にはつかえないの???
902 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 15:51:19 ] 仕様書嫁
903 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 16:04:25 ] 実装依存で使える場合もあるかもしれないけど、 どこでも動く保証はないっていう感じだったきがする<GET、POST同時 まあ、普通にやめといた方がいいと思う
904 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 19:07:01 ] >>901 os.environ['QUERY_STRING']に入ってない?
905 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 23:25:33 ] GET,POSTはHTTPのメソッドの名前。当然どっちかしか使えん。 HTTPの仕様上はPOSTで「?」付URLを呼び出せる。 >>904 の言う通り cgi.parse_qs(os.environ['QUERY_STRING']) でよかったとオモ POSTされたデータは cgi.parse(sys.stdin) か cgi.FieldStorage()
906 名前:デフォルトの名無しさん [2008/03/26(水) 23:27:08 ] ttp://www.openplans.org/projects/plone-summer-of-code-2008/project-ideas ふるって応募を!
907 名前:デフォルトの名無しさん mailto:sage [2008/03/26(水) 23:31:48 ] POSTのときにQUERY_STRINGとれない環境もある
908 名前:デフォルトの名無しさん mailto:sage [2008/03/27(木) 08:08:23 ] panel = wx.Panel(frm,-1) こんなんがあって、panelをデストラクタするにはどうすれば良いんでしょうか。 ある状況でパネルを削除したいんですが。
909 名前:デフォルトの名無しさん mailto:sage [2008/03/27(木) 08:24:14 ] panel.Destroy() del panel じゃね
910 名前:デフォルトの名無しさん mailto:sage [2008/03/27(木) 08:27:21 ] おお!できました。 ありがとうございます。
911 名前:デフォルトの名無しさん mailto:sage [2008/03/27(木) 18:49:43 ] 297 :デフォルトの名無しさん:2007/12/23(日) 02:11:55 >>294 =269 か? メソッドオーバーロードはrubyではできない。こんな感じで自分で処理しなさい def meth(arg) if arg.kind_of?(String) puts '文字列' else case arg when Array then puts '配列' else puts 'その他' end end end それとrubyの配列(Array)に次元なんて無い。配列が入れ子になってるだけ。 python だと、どう処理を描けば良いですか?
912 名前:デフォルトの名無しさん mailto:sage [2008/03/27(木) 18:56:45 ] Pythonでも同じだよ 引数の型とか数を調べて分岐するだけ というかrubyスレの話題を持ってこられると色々勘ぐりたくなるんだが
913 名前:デフォルトの名無しさん mailto:sage [2008/03/27(木) 19:27:49 ] >>912 メソッドオーバーロード python www.google.co.jp/search?q=%E3%83%A1%E3%82%BD%E3%83%83%E3%83%89%E3%82%AA%E3%83%BC%E3%83%90%E3%83%BC%E3%83%AD%E3%83%BC%E3%83%89%E3%80%80python&hl=ja&lr=lang_ja&start=20&sa=N たまたまググッたら、それらしいコードが見つかったので 張ってみますた。深い意味はありませんです。。。 def mes(arg): if isinstance(arg, str): print '文字列' elif isinstance(arg, list): print '配列' else: print 'その他' とか。引数に文字列渡して if arg == '文字列': elif arg == 'リスト': else: みたいにするのとか。これくらいしか思い浮かばない罠。ご飯食べてくる
914 名前:デフォルトの名無しさん mailto:sage [2008/03/27(木) 20:30:09 ] とりあえず思いついた適当なコード import sys class OverloadMethod(object): functions = [] def __call__(self, *args, **kwargs): for function in self.functions: if len(args) == function.func_code.co_argcount: return function(*args) raise NotImplementedError def overload(function): obj = sys._getframe(0).f_globals.get(function.__name__) if obj is None: obj = OverloadMethod() obj.functions.append(function) return obj if __name__ == '__main__': @overload def foo(a): print a @overload def foo(a, b): print a + b foo(1) foo(1, 2)
915 名前:デフォルトの名無しさん mailto:sage [2008/03/27(木) 20:55:23 ] Guido謹製 www.artima.com/weblogs/viewpost.jsp?thread=101605
916 名前:914 mailto:sage [2008/03/27(木) 21:02:19 ] スゲーGuidoパパとほとんど一緒じゃん
917 名前:913 mailto:sage [2008/03/27(木) 21:16:33 ] >>914 def overload(function): obj = sys._getframe(0).f_globals.get(function.__name__) if obj is None: obj = OverloadMethod() # コンストラクタみたい obj.functions.append(function) # 関数をストックしてく return obj >>> foo(1) # ストックした関数をポップする >>> foo(1,2) >>> foo(1,2,3) <class exceptions.NotImplementedError at 0x000000000000002C> sys._getframe(0).f_globals のところを globals() にしたら ironpython でも動作確認取れますた。 dir()で表示されるけど, まだ実装されてないのね…_getframe ValueError: _getframe is not implemented annotation で潜らしてポップするか… 勉強になりますた。dくす♪
918 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 02:15:51 ] >>913 キーワード引数
919 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 03:54:18 ] www.linux-foundation.jp/modules/tinyd3/index.php?id=20 何か意図的に抜いてるような…
920 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 09:23:04 ] Pythonだけに見事にハブられてますね
921 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 09:34:12 ] うわぁ・・・^^;
922 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 12:41:32 ] エーとおもたがperlも入ってなくね? どういう基準かよくわからんな
923 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 12:43:15 ] Perl/PHP/Rubyは二重丸じゃないか
924 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 12:55:46 ] Pythonの擬似スレッドって、いずれちゃんとしたスレッドになる予定とかってないんですか?
925 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 13:03:26 ] GILのことなら多分とれないよ
926 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 14:53:41 ] 以前にここに貼ってあったpython チートシートのリンクがみつからない
927 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 16:04:50 ] www.google.co.jp/search?&q=python+cheat+sheet www.google.co.jp/search?&q=python+cheat+pdf
928 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 17:01:20 ] バイナリデータをファイルに書きたく思っています。 例えば4バイト整数10ならば、f.write('\x00\x00\x00\x0a') というように。 上記を、例えば f.write(hoge(10, 4)) で実現できるような 既存の関数hogeのようなものがあれば、ご教示頂けないでしょうか? IEEE浮動小数点についても同様なものがあれば教えて頂きたいです。
929 名前:デフォルトの名無しさん mailto:sage [2008/03/28(金) 17:02:41 ] www.python.jp/doc/release/lib/module-struct.html
930 名前:デフォルトの名無しさん mailto:sage [2008/03/29(土) 05:46:36 ] pythonのワンライナーは超絶美的
931 名前:デフォルトの名無しさん mailto:sage [2008/03/29(土) 08:24:23 ] urllib2のmultipart/form-dataサポートマダー
932 名前:デフォルトの名無しさん mailto:sage [2008/03/29(土) 10:05:49 ] >>931 ドキュメントにツカエネーヨって書いてあるし今更機能仕様を変える気もないんじゃね? これはもう自分でurllib3を作るしか
933 名前:デフォルトの名無しさん mailto:sage [2008/03/29(土) 10:08:34 ] urllib2ってメモリリークするよね?
934 名前:デフォルトの名無しさん mailto:sage [2008/03/29(土) 15:02:28 ] python で 宣言できる関数の上限値とかどれくらいなんだろうか? 1万-10万… 10万くらいなら動きそう? メモリ上に保持できる辞書としての 要素数の限界値? (よくわからん)
935 名前:928 mailto:sage [2008/03/29(土) 15:12:30 ] >>929 おー、これですこういうのです。超速レスありがとうございました!
936 名前:デフォルトの名無しさん [2008/03/29(土) 15:43:27 ] >>934 import sys def mksrc(n): print """ def %s(): return %d """ % ('func%d' % n, n) if len(sys.argv) < 2 or not sys.argv[1].isdigit(): print 'usage: hoge.py N' else: for i in range(int(sys.argv[1])): mksrc(i) for i in range(int(sys.argv[1])): print 'print func%d()' % i $ hoge.py 100001 > fuga.py $ fuga.py とりあえず10万は楽勝みたいだ あとは任せた
937 名前:デフォルトの名無しさん [2008/03/29(土) 16:00:39 ] 100万は死んだ ファイルサイズにワロス
938 名前:デフォルトの名無しさん [2008/03/29(土) 16:03:39 ] 100万通過 >>937 OSとかメモリ容量とかによるんで内科医
939 名前:デフォルトの名無しさん [2008/03/29(土) 16:18:24 ] おまいら阿呆だな まで読んだ