Python の宿題ここで答えます Part 1at TECH
Python の宿題ここで答えます Part 1 - 暇つぶし2ch262:デフォルトの名無しさん
07/05/07 15:42:34
>>261
> gcc は gnu c comliler の略ですよね

違います。もっと落ち着いてちゃんと調べましょう。

263:デフォルトの名無しさん
07/05/07 16:03:31
あのさ、よく分からんのだけど、Fortran コンパイラを使ったこともないような人が
何ゆえ F2PY を使おうとしているの?

SciPy や NumPy を使いたいだけなら Fortran コンパイラの出る幕などないと思うのだが。
禿しく間違った方向に進んでいる希ガス。

264:254
07/05/07 16:08:56
>>262
GNUコンパイラコレクション - Wikipedia
URLリンク(ja.wikipedia.org)
>当初はCコンパイラとして開発され、GCCは GNU C Compiler を意味していた。しかし、
>もともと多言語を想定して設計されており、 GNU C Compiler と呼ばれていたときでも
>多くの言語をサポートしていた。現在でも GNU C Compiler の意味で「GCC」と呼ぶ
>ことも多い(ちなみに GNU C Compiler の実行ファイルの名称もgccである)。
>なお、GNU C++コンパイラをG++、GNU JavaコンパイラをGCJ、GNU AdaコンパイラをGNATと呼ぶ。

gnu compiler collection (広義のgcc)
- gnu c compiler (狭義のgcc)
- gnu c++ compiler (g++)
- gnu java compiler (gcj)
- gnu ada compiler (gNAT)
- gnu fortran compiler (g77)

コレクションだったのですね orz
-------------------------------------------------------------------------
MinGW - Wikipedia
URLリンク(ja.wikipedia.org)

>MinGW(Minimalistic GNU for Windows)
>または、Mingw32 は GNU ツールチェーン(GCCなど)の Windows 移植版である。
------------------------------------------------------------------------

つまるところ gnu compiler collection (not gnu c compiler) の
windows移植版が MinGW なのですね. 勉強になりまた。ありがとです ><

265:デフォルトの名無しさん
07/05/09 19:55:47
URLリンク(d.hatena.ne.jp)

実行しても doctest の結果が表示されないのですが
どうしてでしょうか?

# a.py
import doctest

def foo(a, b):
'''return a+b
>>> foo(10, 1)
12'''
return a+b

doctest.testmod()

は、うまく実行できていました…

266:265
07/05/09 20:33:56
すみません。doctestって成功したときは何も
表示されないんですね orz 自己解決スマソ。

267:デフォルトの名無しさん
07/05/13 18:13:11
例外処理についての質問です。

# -- coding: cp932 --
import urllib2

url='URLリンク(www.yahoo.co.jp)'; print url
try:
  print 'try try try'
  f=urllib2.urlopen(url) ##urlをオープン
except IOError, (errno, strerror): ##オープンできないときは
  out= 'web error'
  print out
else:       ##オープンできたら
  txt=f.read()  ##htmlファイルを読み込む
  print txt

> except IOError, (errno, strerror): ##オープンできないときは
>ValueError: need more than 1 value to unpack

というエラーが出てしまい上手くゆきませんでした。
環境は、winxp, python2.5 です。どうぞよろしくお願い致します。

268:デフォルトの名無しさん
07/05/13 20:56:17
exceptの書式が違う。

except IOError, e: # eはIOErrorオブジェクト
print e

269:デフォルトの名無しさん
07/05/13 22:04:40
>>267
urllib2.urlopen の失敗時に発生している例外が IOError なら
> except IOError, (errno, strerror): ##オープンできないときは
のようにタプルとみなしてアンパック代入できるんだけど、
実際に発生しているのは IOError のサブクラスである URLError のインスタンス。
これはなぜか IOError のサブクラスのくせにタプルとみなせない。
ただ URLError の reason 属性を使えばこう書ける:

except urllib2.URLError, urlerror:
  errno, strerror = urlerror.reason

270:デフォルトの名無しさん
07/05/14 00:42:07
URLError 以外にも WindowsError やら ValueError やら起こるみたいだから
except Exception, e:
みたいに一般的に書いとくのがいいんジャマイカ。

271:デフォルトの名無しさん
07/05/14 01:53:29
except IOError, e: # eはIOErrorオブジェクト
  print e
>>> <urlopen error (11001, 'getaddrinfo failed')>

と書くか、
from urllib2 import URLError して

except URLError, urlerror: # urlerrorはURLErrorオブジェクト
  errno, strerror = urlerror.reason
  print errno, strerror
>>> 11001 getaddrinfo failed

と書けば大丈夫。

# URLError is a sub-type of IOError, but it doesn't share any of
# the implementation. need to override __init__ and __str__
URLリンク(www.koders.com)
>>269
このことですよね…。何となく例外の引数は一つ以上付けないほうが
無難そうな気がしました。というかあまり他の言語でも例外の引数
を一つ以上持ってるのを見たことがないですし。

どうもありがとうございました!

272:デフォルトの名無しさん
07/05/14 01:54:41
>>270
よくわからないときは、Exceptionでやってしまうのもありでしょうか?
何か、それはそれで問題が生じそうな気もするようなしないような…(^^;)

273:デフォルトの名無しさん
07/05/14 03:03:16
>>272
複数の例外が起こる状況で、例外毎に処理を変えたいときは except 節を複数書く必要があるけど、
一律にキャッチしたいだけなら except Exception, e: または except: だけで十分かと。

274:デフォルトの名無しさん
07/06/01 13:47:43
ほしゅ

275:デフォルトの名無しさん
07/06/01 14:58:43
【 課題 】数当てゲームを作ってみよう。一桁の数を入力してもらう。
その数が、秘密の数と一致していたら、「上がり」と表示して終了する。
もし、秘密の数よりも大きければ、「大きすぎ」と表示して、再度入力をしてもらう。
逆に小さければ、「小さすぎ」と表示して、再度入力をしてもらう。
秘密の数は、プログラムの最初で変数に代入しておく。

【 補足 】某大学サイトでpythonを学習しているのですが(当方、大学生ではありません)、
下のどこがいけないのかわかりません・・・
文末の「;」はつけないと何となく不安なのでつけてあります。

# 数当てゲーム
print "数当てゲーム\n";
question = "半角で一桁の数字を入力して下さい。";
answer = '8';
a = answer;
input = raw_input(question);
while input != '':
    if input == a:
        print '上がり。';
        break;
    elif input < 9;
        print '小さすぎ。/n';
        input = raw_input(question);
    else:
        print '大きすぎ。\n';
        input = raw_input(question);

276:デフォルトの名無しさん
07/06/01 15:05:16
elif input < 9;
じゃなくて
elif input < a:
だろ

277:デフォルトの名無しさん
07/06/01 15:07:54
お! 動いた!

>>276
ありがとうございます。

278:デフォルトの名無しさん
07/06/01 15:12:34
>>> input = raw_input('Enter: ')
Enter: 8
>>> input
'8'
>>> input == 8
False
>>> int(input) == 8
True

がんばれー

279:デフォルトの名無しさん
07/06/01 17:00:24
セミコロンなんて付ける癖にしているからへんてこな間違いをやってしまうのだ

280:デフォルトの名無しさん
07/06/01 19:40:17
inputというのはビルトイン関数名でもあるので、それを変数名に使うのは行儀が良くない、
で、この場合raw_inputよりもinputを使った方が簡単。

281:デフォルトの名無しさん
07/06/03 06:24:50
>>> def myfunc(): print input()
...
>>> myfunc()
__import__('os').unlink(<漏れの大事なファイル>)
None

便利なファイルシェルだな。

282:デフォルトの名無しさん
07/06/03 07:02:25
公式ドキュメントより
> input( [prompt])
> eval(raw_input(prompt)) と同じです

兄貴と呼ばせてくれ >>281

283:デフォルトの名無しさん
07/06/10 13:48:47
ファイル(バイナリ)から4byteづつ読んで実数表示する
のはどう書きますか?

284:デフォルトの名無しさん
07/06/10 15:13:44
import array
ary = array.array('f')
fo = file('test.bin', 'rb')
while True:
 try:
  ary.fromfile(fo, 1)
 except EOFError:
  break
 print ary.pop()
fo.close()

285:383
07/06/11 18:27:37
>>284
しかし何も起こりませんでした。
インストしたpythonは
python-2.5.msi
pywin32-210.win32-py2.5.exe

286:デフォルトの名無しさん
07/06/11 19:44:33
はい、次

287:デフォルトの名無しさん
07/06/11 21:07:35
>>285
その4バイトのフォーマットが何なのか書かないとどうにもならないよ
ところで1バイトずつ読み込んでそれを表示するのなら書けるんだよね?

288:285
07/06/12 08:20:09
>>287

想定は3Dモデルですが、公開されてるフォーマットでは
無い為とりあえず頂点のみ収めたファイルを指定しました。

バイナリの読み込み自体わかりません。スミマセン

289:デフォルトの名無しさん
07/06/12 11:06:26
何も起こりませんでした… ってどんな呪文だよ

290:デフォルトの名無しさん
07/06/12 12:03:39
>>288
単純にCのfloat型をファイルに書き出したものなら>>284のでいけるはず
まず>>284のがちゃんと動くようにするのが先決だね

・時下げ部分の全角空白を半角空白に置き換える
・その3Dデータを test.bin の名前でいっしょに置く

をしている?
それをして動かないなら動かないなりにエラーメッセージが出ているはずなので
そのエラーメッセージを書いてください

291:288
07/06/12 14:52:16
>>290

丁寧にありがとう御座います。<(_ _)>

> except EOFError:
ここで止まっているようでした。
ファイルはtest.binでC:\(あれ? \打った時に確定されてIMEがオフになる~)
に置きました。 これか?
取り急ぎお礼だけ。

292:291
07/06/12 15:18:16
全角空白はエディタ読み込み時に文字化けしていたんで
半角空白にしてたんですが、位置が悪かったようです。
>>284と同じインデント? で動くようになりました。(PythonWin上)

実はPOSERで遊びたい3Dモデルがあるんですが、対応プラグイン
もプラグイン書くにしてもC言語は難しそう。
そこでインタプリタなら出来るんじゃないかと思い……。


4MBのファイル読み込ませたんだけど20分経っても終わらないや……。

293:デフォルトの名無しさん
07/06/13 03:24:29
とりあえず何形式かいうてみそ。

294:292
07/06/13 20:02:46
>>293

えーと……ILUUSIONってとこのゲームのデータです。
今現在有志の手によりMetasequoiaのmqo形式での
読み書きは出来ます。
Metasequoiaがモーション対応してない為頂点カラー
にエンベロープデータを保持させるという特殊な手法
なので頂点の削除追加が困難になっています。

手持ちのPoserとXSI fndがPython対応しているんで
ちょっと夢見てしまったのでした。

295:デフォルトの名無しさん
07/06/13 20:59:13
しかし何も起こりませんでした。

296:デフォルトの名無しさん
07/06/13 21:00:51
そんなような台詞を多用するRPGが昔ありました

297:デフォルトの名無しさん
07/06/16 18:20:53
某大学でPYTHONの授業を取っているのですが、先生が全く何も教えてくれず放置
なのと、自分が他の課題で常に手一杯なので、PYTHONの知識については皆無に等しいです。
ですが、期限がとうとう来週までに迫ってしまいました。。。
課題は自由なのですが、「自分又は他者にとって有用性のあるもの」
とのことなので、以下のような課題を設定しました。どなたか分かる方
がいらっしゃれば、丸投げですが是非よろしくお願いしますm(..)m
□課題
「ホームページ(自分が作りました)の掲示板に書き込みがされたら、
 自動的にメーリングリストのアドレス宛に更新通知を送り、ついでにその掲示板のアドレスもそのメールに記す。」
というものです。
出来ればわかり易く「ここにHPのアドレスを入れる」とか「ここにメーリングリストのアドレスを入れる」
等のコメントを加えていただければと思いますm()m。
□提出期限
6月25日(月)
です。よろしくお願いします。


298:デフォルトの名無しさん
07/06/16 18:23:38
ネットワークじゃなきゃならんのか?
自分のレベルを考えたらもっと楽なものにしないとボロが出るぞ。

299:デフォルトの名無しさん
07/06/16 18:25:15
>PYTHONの知識については皆無に等しいです

じゃあ、何ならできるんだ?
Perlなら、WebProgバリバリか?


300:デフォルトの名無しさん
07/06/16 18:38:16
>>297
掲示板プログラムはすでにあるの?
それを改造しないでPythonで定期的にチェックしてメール飛ばすの?

301:デフォルトの名無しさん
07/06/16 19:15:36
  →諦める   諦めない

302:デフォルトの名無しさん
07/06/16 19:17:52
>>297を読む限りpython知識だけでなく、webとかcgi知識も皆無に見えるんだが?

303:デフォルトの名無しさん
07/06/16 19:47:37
まあがんばれ

304:updatechecker.py
07/06/16 20:01:59
>>297 どぞ。

# -*- coding: Shift_JIS -*-

import urllib, smtplib
from email.MIMEText import MIMEText
from email.Charset import Charset

def main():
    # 掲示板の URL
    bbs = "スレリンク(tech板)l50"
    # 通知メールの宛て先
    mail = "****@****.****.ne.jp"
    # SMTP サーバのホスト名
    smtp = "mail.****.****.ne.jp"
    if updated(bbs):
        print "updated"
        notify(mail, smtp, bbs)
    else:
        print "not updated"

def updated(URL):
    CACHE_FILE = "updatechecker.dat"
    # キャッシュファイルに保存したページ内容を取り出す
    try:
        file = open(CACHE_FILE, "rb")
        cached_contents = file.read()
        file.close()
    except IOError:
        cached_contents = None

305:304の続き
07/06/16 20:04:38
    # 現在のページ内容を得る
    file = urllib.urlopen(URL)
    contents = file.read()
    file.close()
    # 現在のページ内容をキャッシュファイルに保存する
    file = open(CACHE_FILE, "wb")
    file.write(contents)
    file.close()
    # ページ内容が変わっていたら更新アリと判定 (真偽値を返す)
    return contents != cached_contents

def notify(address, server, URL):
    text = u"掲示板が更新されました。\n" + unicode(URL, "ascii")
    charset = Charset("ISO-2022-JP")
    msg = MIMEText(text.encode(charset.input_codec, "replace"))
    msg.set_charset(charset)
    msg["Subject"] = "Update notification from updatechecker.py"
    msg["From"] = '"updatechecker.py" <%s>' % address
    msg["To"] = address
    smtp = smtplib.SMTP()
    smtp.connect(server)
    smtp.sendmail(msg['From'], msg['To'].split(), msg.as_string())
    smtp.quit()

if __name__ == "__main__":
    main()

306:デフォルトの名無しさん
07/06/16 20:48:06
傍から見てたんだけど、HTMLを丸ごとGETして
キャッシュと比べるっていうのは思いつかなかった。
(掲示板がどんなHTMLを吐くかも不明なのに
 更新チェックなんて無理とか思ってた)
勉強になったよ、ありがとー>>304

307:デフォルトの名無しさん
07/06/16 20:59:56
大学生にもなって先生が教えてくれないって泣き言なんて馬鹿じゃね?
正直今の甘ったれた根性で社会に出るとお前個人じゃなくて同僚の迷惑になるのでそのまま留年してな

308:デフォルトの名無しさん
07/06/16 23:52:11
何も教えてくれないなんてあるのか。
>297 が講義に出席してなかったとかじゃなくて?

309:デフォルトの名無しさん
07/06/17 00:01:00
単にurllibの名前だけしか教えてくれなかったから使い方わからなーい!
とかそういう感じじゃないかなぁ・・・

310:デフォルトの名無しさん
07/06/17 00:23:45
月曜日が楽しみですね

311:デフォルトの名無しさん
07/06/17 07:47:19
>>306
掲示板の内容以外のものが、動的に生成されてるとだめじゃない?
テキスト広告とか、参照元とか表示してるところあるじゃん。
2chなら、おすすめ2chとか。

312:デフォルトの名無しさん
07/06/17 08:42:32
自分のHPならそれくらい把握できるだろ。
そのぶぶんだけ比較対象からはずせばいいだけジャン。

313:306
07/06/17 09:53:57
>>311
もちろん広告などが入ったらアウトだけど、
それは出題者が示して無いから仕方ない。
大抵の掲示板にはLast-ModifiedやETagは使えないから
>>304のアプローチがベストじゃないかな。
実際の利用時には、>>312が書いてくれたように
余分な箇所を削るフィルタを掲示板ごとに書くことになると思う。
あと、おすすめ2chは、datのLast-Modifiedを比較すればOK。

314:デフォルトの名無しさん
07/06/17 12:31:28
そういう問題があるからRSSとかが発明されたわけだ

315:デフォルトの名無しさん
07/06/17 15:05:09
illusionってエロゲメーカーか。

316:デフォルトの名無しさん
07/06/17 16:15:03
>>314
いやRSSは最初はサイトサマリー
blog のエントリーの更新を通知する、程度まで援用されてはいるけど
bbs の書き込みをRSSで配信している例なんてほとんど見ないよ

317:デフォルトの名無しさん
07/06/17 16:32:02
フリー・レンタルBBS業界の一般的な話は知らないけど
teacupはRSS配信してるみたいね

318:デフォルトの名無しさん
07/06/17 19:07:16
>>316
BBSというシステムがあまり最近の流行ではないから、古いシステムをそのまま使ってることが
多いというだけだと思う。いまどき新規に開発するBBSでRSSに対応しないというのはあり得ない。

319:デフォルトの名無しさん
07/06/18 01:16:36
>>318
blog のコメント欄なんかは RSS 配信しない事が多いね
まあどこまでを BBS と言うかによるわけだけど

320:デフォルトの名無しさん
07/06/18 20:25:19
さて月曜日ですよ。 >297 はどこの課題だったのかなー。

321:デフォルトの名無しさん
07/06/18 20:28:01


322:デフォルトの名無しさん
07/06/19 06:20:26
シカト来たーーー

323:デフォルトの名無しさん
07/06/19 15:13:28
>>319
それは確かにそうだ。
たまには、コメントやトラックバックのRSSを配信できるシステムもあるが、主流ではないか

324:デフォルトの名無しさん
07/06/20 11:16:36
後で考えたら結局要らなかったのですが一応。

配列の配列を引数にとって、行列を入れ替える関数って
どう書けばいいでしょうか?
具体的には
[
[ 1, 2, 3, 4],
[ 5, 6, 7, 8],
[ 9,10,11,12],
]
を渡すと
[
[ 1, 5, 9],
[ 2, 6,10],
[ 3, 7,11],
[ 4, 8,12],
]
を返すようなものです。

325:デフォルトの名無しさん
07/06/20 11:36:25
zip関数を使う

326:デフォルトの名無しさん
07/06/20 11:48:26
>325
zip(*lst) でほぼ理想通りの結果が出ました!感謝!

327:デフォルトの名無しさん
07/06/20 13:22:53
2階層は zip で結構イケルんですけど
3階層以上の配列(テンソル?)だと
あまりいい手はないですよね

numpy の類を使うしかないかな

328:デフォルトの名無しさん
07/06/20 19:58:32
25日は来週の月y・・・

329:デフォルトの名無しさん
07/06/20 23:08:10
まだ猶予があったのか。ギリギリになってあわてる奴よりはなんぼかましですね。

330:timer
07/06/22 21:34:32
具体的な例ではなくて申し訳ないのですが、実行したい関数を数秒毎に繰り返し実行させる方法(ライブラリでもいいです)
が教えていただきたいのですが。。。お願いします!!


331:デフォルトの名無しさん
07/06/22 21:46:04
import time

def hoge():
 print 'hoge'

while(True):
 hoge()
 time.sleep(1)

332:デフォルトの名無しさん
07/06/22 21:46:12
>>330
import time
while True:
    foo()
    time.sleep(3)

fooが重い処理なら、例えばスレッドなんかを作る。

import time, thread
while True:
    thread.start_new_thread(foo, ())
    time.sleep(3)

URLリンク(www.python.jp)
URLリンク(www.python.jp)

333:デフォルトの名無しさん
07/06/24 20:36:07
youtube-dlをjp.youtube.comとwww.youtube.com
の両対応にしてください。
おながいします。

334:timer
07/06/25 01:38:28
>>331>>332
ありがとうございました!無事解決しました!!


335:デフォルトの名無しさん
07/06/26 02:06:18
age

336:デフォルトの名無しさん
07/07/13 18:44:07
保守あげ

337:デフォルトの名無しさん
07/07/23 20:13:20
[1, 1, 2, 2, 2, 3, 3, 4, 4, 1, 2]という数値のリストがあって、
それはリストのネストのレベルを表してます。

このリストをそのレベルどおりにネストさせるには、どうすればいいですか?
[1, 1, [2, 2, 2, [3, 3, [4, 4]]], 1, [2]]


338:デフォルトの名無しさん
07/07/23 20:46:10
最小値より大きいものを1つのリストにまとめたリストを返す関数を作って再帰
ただサイズが大きいと計算時間が厳しいと思う

339:デフォルトの名無しさん
07/07/23 23:02:26
>>337
ミもフタもない解答
def f(lst):
  lvl=lst[0]
  ans = '['*lvl + '%d'%lvl
  for i in lst[1:]:
    if i==lvl:
      ans += ',%d' % i
    elif i>lvl:
      ans += ',' + '['*(i-lvl) + '%d'%i
    else:
      ans += ']'*(lvl-i) + ',%d'%i
    lvl = i
  return eval(ans+']'*lvl)

340:デフォルトの名無しさん
07/07/24 00:36:15
【 課題 】
次の要求を満たすフィルタプログラムを作れ。
1.標準入力から行を読み込み、空白をカンマに変換し、標準出力に出力する
2.連続した複数の空白はひとつの空白と同じと見なす
3.タブ文字も空白と見なす
4.オプション等は設けない
5.フィルタとして動作するので余分なメッセージ類は一切出力しない

例として「1 Bill  1955 Oct 28」と入力したら「1,Bill,1955,Oct,28」と出力されるようにします。

オブジェクトの名前は次のように定義する
line      標準入力から入力した行
termList   lineにsplitメソッドを適用して生成したリスト
term      リストの各要素
ouputString 標準出力に出力する文字列


outputString = ’’
for term in termList[:-1]:
outputString += term + ’,’
outputString += termList[-1] + ’\n’
sys.stdout.write(outputString)

上記のコーディング例を参考に作成せよ。

【 期限 】7月30日(月)まで。

何方かよろしくお願いします。

341:デフォルトの名無しさん
07/07/24 00:40:10
# -*- coding: Shift_JIS -*-

def nest(L, level=1):
    L = list(L) # pop で破壊してよいようにコピーを作る
    results = []
    while L:
        # 想定外の要素が見つかったらエラー
        assert not L[0] < level
        # 現在のレベルと等しい要素をそのまま results に追加
        if L[0] == level:
            results.append(L.pop(0))
            continue
        # 現在のレベル以上の要素を集める
        nested_items = []
        while L:
            # 想定外の要素が見つかったらエラー
            assert not L[0] < level
            if L[0] == level:
                break
            nested_items.append(L.pop(0))

342:デフォルトの名無しさん
07/07/24 00:42:48
        # 集めた要素をネストする(再帰)
        results.append(nest(nested_items, level+1))
    return results

assert nest([1, 1, 2, 2, 2, 3, 3, 4, 4, 1, 2]) == [1, 1, [2, 2, 2, [3, 3, [4, 4]]], 1, [2]]

343:デフォルトの名無しさん
07/07/24 00:53:54
>>340
import sys
for line in sys.stdin.readlines():
    termList = line.split()
    outputString = ''
    for term in termList[:-1]: 
        outputString += term + ', '
    outputString += termList[-1] + '\n'
    sys.stdout.write(outputString) 

344:デフォルトの名無しさん
07/08/02 18:07:35
oxtu.py

345:デフォルトの名無しさん
07/08/02 19:06:37
oxtu.py age

346:デフォルトの名無しさん
07/08/12 17:58:39
【 課題 】
宿題じゃないが、アルゴリズム考えててこんがらかったので質問。

lst = [dataX, ..., data2, data1, data0]
newlst = [dataM, ..., dataN+1, dataN]
# len(lst) == 任意, len(newlst) <= 4, M >= X

このようなリストがあった時、newlstをlstに重複なくマージするにはどうしたらよい?

つまり、
lst = [data3, data2, data1, data0]
newlst = [data4, data3, data2]
assert merge(lst, newlst) == [data4, data3, data2, data1, data0]

このときのmergeをどう作ればよいのか知りたい。
なおインデックスに飛びは無く、dataは等価比較可能。

347:デフォルトの名無しさん
07/08/12 18:17:13
list(set(lst + newlst))

348:デフォルトの名無しさん
07/08/12 18:33:50
>>347
すまん、忘れてたが順序関係は維持したままで。
ただしdata同士の順序比較は出来ない。
インデックスは順序のために便宜的につけただけで、実際には通し番号などは無い。

349:デフォルトの名無しさん
07/08/12 22:24:18
> data同士の順序比較は出来ない
> 実際には通し番号などは無い

ちょっ、そうしたら、
lst = [a, b, c]
newlst = [b,x,y]
のとき、c, x, y, の順序はどうやって決めるんだ?

350:デフォルトの名無しさん
07/08/12 22:25:04
ふつうに
for item in newlst:
    if item not in lst:
        lst.insert(0, item)
ではダメなの?


351:デフォルトの名無しさん
07/08/12 22:28:39
あれ、>>346見たら
> インデックスに飛びは無く

って書いてあるな。順序あるのか無いのか、はっきりしてくれ。

352:デフォルトの名無しさん
07/08/12 23:29:08
lst[:lst.index(newlst[0])] + newlst

353:346
07/08/13 04:15:28
質問しといて何だが自己解決した。
色々前提条件説明しきれてなくてスマン。付き合ってくれた人有り難う。
URLリンク(dpaste.com)

要はネットからエントリ型の更新情報をダウンロードしてローカルデータに追加するため、
lstとnewlstに重複した情報があるかもしれないが、そこだけstripしたかったというお話。
エントリに日時情報があればもっと簡単だったんだけどね。

354:デフォルトの名無しさん
07/08/13 08:34:13
>>353
エントリ型って何?

355:デフォルトの名無しさん
07/08/13 08:35:28
>353 を読む限り順序なんてなくて set で要素抽出をすればいいだけじゃん

元の list 保存しておいて orig_list.index( some_data ) で
個別 index はでるんだし

356:デフォルトの名無しさん
07/08/13 15:37:39
最後lstとnewlstの足し算逆じゃね?
ていうか明らかにfor文必要ないから

357:デフォルトの名無しさん
07/08/16 11:32:42
下のような2つのリストがあるとき
a = ["A","B","C","D"]
b = [5, 3, 8, 2]
aのリストをbの値の大きい順にソートしたい、この場合、a = ["C","A","B","D"] b = [8,5,3,2]を求めたいのですがどのように書けばよろしいでしょうか。
アドバイスお掩蓋します。

358:デフォルトの名無しさん
07/08/16 12:00:11
>>> zip(b, a)
[(5, 'A'), (3, 'B'), (8, 'C'), (2, 'D')]
>>> sorted(zip(b, a))
[(2, 'D'), (3, 'B'), (5, 'A'), (8, 'C')]
>>> sorted(zip(b, a), reverse=True)
[(8, 'C'), (5, 'A'), (3, 'B'), (2, 'D')]
>>> [x[1] for x in sorted(zip(b, a), reverse=True)]
['C', 'A', 'B', 'D']
>>> 

359:デフォルトの名無しさん
07/08/16 12:12:37
>>358
zipでこんな簡単にできると思いませんでした。
ありがとうございました。

360:デフォルトの名無しさん
07/08/25 02:27:14
質問です。
外のwebサーバ(自分はドキュメントやCGIスクリプトの設置はできるユーザ権限)にJythonって設置できますか?
やっぱサーバの管理者権限いりますよね?

361:デフォルトの名無しさん
07/08/25 03:40:39
自分でJavaとJythonインスコすればおk。

362:デフォルトの名無しさん
07/08/25 14:19:06
telnet、ssh禁止とかだったらたぶん無理

363:デフォルトの名無しさん
07/08/25 15:37:04
>>362
それがOKならいけるってことですね。
いっちょあやしまれないように暗躍してみます。

364:デフォルトの名無しさん
07/08/25 20:17:55
Jythonについて質問した者です。
ローカル環境でいじくり、無事jythonのインストール方法を理解できました。
これで、python ver 1.5.2からアップデートしない大学のサーバを
出し抜いてやるぜと思ったら、javaすら入っていませんでした。

365:デフォルトの名無しさん
07/08/25 23:51:18
無けりゃ入れるだけよ

366:デフォルトの名無しさん
07/08/27 22:24:08
java設置失敗。
そして良く考えたらJythonとCPythonとの互換性も追い付いているのかどうか良く知らない・・・。

ファイルの実行や一般的なUNIXコマンドを使う権限があるので、リモートでPython2.5をコンパイルしてみた。
が、ソケットのヘッダファイルを読み込めなかった。
くそっくそっ。
かっこいいCGI置きたいよぅ。

367:デフォルトの名無しさん
07/08/28 00:26:15
いまどきCGIである時点であまりかっこいいとは言えない

368:デフォルトの名無しさん
07/08/28 10:31:19
結局GUIは、
・Tkinter
・wxPython
のどちら(その他にもありますか?)が良いのでしょうか?

環境はMac(できればLinuxも)、
一般的で、かつ、将来性のあるGUIを選びたいです。

369:デフォルトの名無しさん
07/08/28 10:42:50
wxPython

370:368
07/08/28 10:48:29
ラジャ。

ついでですが、Tkinterのダメな理由を教えて下さい。
(それを知っておけば心残り無くwxPythonできるので)

371:デフォルトの名無しさん
07/08/28 10:53:11
Tkinterは、ちょっと見たら気づくと思うけど
ウェジットがしょぼい。

簡単なスクリプトには使えるだろうけど…


372:368
07/08/28 11:04:25
ではショボイTkinterはやめておきます。

ところで、Pythonで配布されてるGUIツールってありますか?
サンプルとかコマンドで動くスクリプトはネットに転がってますが、GUIスクリプトはあんまり見ないような。

373:デフォルトの名無しさん
07/08/28 11:50:00
>>372
IDLE

374:デフォルトの名無しさん
07/08/28 11:58:05
>>372
wxPythonをインストールすれば、XRCedっていう_GUIでI編集出来るツールが入ってる。
あと、wxPython に決めたら決めたで、Mac板のプログラムスレにも書いとけよ。

375:368
07/08/28 12:36:35
>>374
wxPythonにケテーイはしましたが、マカーとはマカー文脈で会話するので...

376:デフォルトの名無しさん
07/08/28 13:50:51
wxgladeがいいんじゃね?

377:368
07/08/28 13:57:18
そうなの?...

378:368
07/08/28 14:03:09
あ、wxGladeってのはwxPythonのIDEみたいなものですね。

了解しました。使ってみます。
レイアウトマネージャ方式っていうか、位置の融通は無さそうですね。
コツを掴めば良いのでしょうが。

379:デフォルトの名無しさん
07/08/28 14:11:43
スレリンク(appli板:79番)

どなたか頼みます。。。。

380:デフォルトの名無しさん
07/11/12 00:23:27
pythonで作られたwikiが使えるサーバっていうか、
ここ↓みたいなのありますか?
URLリンク(wiki.fdiary.net)
(rubyで作られたwiki実装のhikiで自分?のwikiを作れる)

381:デフォルトの名無しさん
07/11/12 10:15:16
URLリンク(wiki.python.org)


382:デフォルトの名無しさん
07/12/03 01:27:52

【 課題 】
テキストファイルを読んで、
その先頭に'>'を追加したファイルを出力するコードを書きなさい
【 用語 】
【 期限 】出来れば明日中になんとかしたいです。
【 Ver  】2.5です。
【 補足 】テキストファイル(test.txt)の"先頭に"'?'を追加するにはどうしたらいいんでしょうか?open関数の"w"だとテキストの中身消去しちゃうし・・お手上げです。ヒントでも良いので教えてください。

自分でやった結果↓

f=open ("test.txt","r")
w=f.read()
a=">"+w
f.close()

-------
【 課題 】
shift_jisのファイルを読んで
utf-8に変換したファイルを出力するコードを書きなさい。
【 用語 】
【 期限 】出来れば明日中になんとかしたいです。
【 Ver  】2.5です。
【 補足 】

自分でやった結果↓

#coding: shift_jis

f=open("kadai7.txt","r")

383:デフォルトの名無しさん
07/12/03 01:40:58
一つ目:
file = open("test.txt", "r")
lines = file.readlines()
file.close()
file = open("test.txt", "w")
for line in lines:
    file.write(">"+line)
file.close()

二つ目:
import codecs
src = codecs.open("sjis.txt", "r", encoding="sjis")
dest = codecs.open("utf8.txt", "w", encoding="utf-8")
dest.write(src.read())
dest.close()
src.close()

がんばりましょう。

384:デフォルトの名無しさん
07/12/03 01:45:37
やさしいなぁ。。

385:デフォルトの名無しさん
07/12/03 02:05:37
>>382
# 1.
import os
file("test2.txt", "w").writelines(">" + x for x in file("test.txt"))
os.remove("test.txt")
os.rename("test2.txt", "test.txt")

# 2.
doc = unicode(file("sjis.txt").read(), "Shift_JIS")
file("utf8.txt", "w").write(doc.encode("utf-8"))

386:382
07/12/03 05:00:17
即レスありがとうございました。
本当に感謝してます。

教えてもらった答え丸写しじゃなく自分なりに工夫して動作確認してみます。
いつの日か教える側に回れたら・・・

ありがとうございました。

387:デフォルトの名無しさん
07/12/03 20:47:50
nanoblog

388:デフォルトの名無しさん
08/02/03 19:52:36
URLリンク(polog.org)

(14989440..15318688).step(1) do |i|
 chr_a = i.to_s(16).scan(/../).map{|s| eval("0x#{s}")}
 next unless(
       chr_a[1] >= 128 &&
       chr_a[1] <= 191 &&
       chr_a[2] >= 128 &&
       chr_a[2] <= 191
       )
 puts "#{chr_a.map{|i| i.chr}.join}\t#{chr_a.join(',')}"
end

Python ですべての漢字を列挙するにはどうしたら
良いでしょうか?

389:デフォルトの名無しさん
08/02/03 21:52:35
import unicodedata
kanji = []
for i in range(0xffff):
  c = unichr(i)
  n = unicodedata.name(c, '')
  if 'CJK' in n and 'IDEOGRAPH' in n:
    kanji.append(c)
print len(kanji)

何を漢字とみなすかが問題だけど、一般的にはこんなもんでいいんじゃないかな

390:デフォルトの名無しさん
08/02/03 21:54:13
kanji.py

for c in range(0xe4b880, 0xe9bea1):
  c0, c1, c2 = ((c / 65536) % 256, (c / 256) % 256, c % 256)
  if c1 >= 128 and c1 <= 191 and c2 >= 128 and c2 <=191:
    print '%c%c%c\t%d\t%d\t%d' % (c0, c1, c2, c0, c1, c2)

$ kanji.py > hoge
$ cat hoge
一  228  184  128
...
龠  233  190  160


391:デフォルトの名無しさん
08/02/04 01:25:55
>>388
それRuby?
ださすぎw

392:デフォルトの名無しさん
08/02/04 02:38:29
>>389
fd = open("kanji_cjk.dat", "a+")
i = 1
for e in kanji:
 temp = e.encode('utf-8')
 #print temp,
 i = i + 1
 if i%16 == 0:
  temp = temp + "\n"
 fd.write(temp)
fd.close()

始めよくわからない漢字が表示されてエンコードの
指定の仕方が悪いのかと躓いたのですがよくよく考えたら
使ってるエディタがutf-8文字列を認識してなく文字化け
しているだけのようでした orz

>>389-390
len(S1) 27973個, len(S2) 20897個
共通集合(S1とS2に共通な要素) 20897個
for c in S1.intersection(S2):
差集合(S1特有の要素) 7076個
for c in S1.difference(S2):

集合演算が地味に便利だと思いました…
どうもありがとうございました!

393:デフォルトの名無しさん
08/02/07 16:51:26
URLリンク(www.uploda.org)

英語サイトならIE.LocationNameで取得した文字列を扱えるのに
日本語のサイトの場合にはエラーになり、
.encode('utf-8')などをつけてエラーを回避しても文字はアルファベット部分しか表示されません。
ほかにもfindとか文字列操作したいけどうまくいかなくて
ぶっちゃけこのスクリプトが日本語表示まで含めて動くコードを教えてください。


394:デフォルトの名無しさん
08/02/07 16:55:52
いやなスクリプトだなw

395:デフォルトの名無しさん
08/02/07 17:40:27
どういう宿題だよ

396:デフォルトの名無しさん
08/02/07 17:43:02
2ゲットスクリプトじゃなければ答える人もいただろうにね

397:デフォルトの名無しさん
08/02/07 17:48:19
真の目的を隠したスクリプトに書き換える程度の応用力が望まれますね

398:デフォルトの名無しさん
08/02/07 17:50:41
>>393
strに代入すんなよ

399:393
08/02/07 17:56:13
いや、とっくに規制食らって投稿できないからいらぬ心配ですよ。

★080204 ニュース速報+「糞スレは立てない約束」AA2get荒らし報告
スレリンク(sec2chd板)

このスクリプトを選んだのは作ったやつの中で短いからで、
別に動くのを確認したらそれでいいんですよ。

荒らしっていうけど3以降には書き込んだりしないんだから残り998スレはほかの人が自由に書き込めるんですよ?
何の問題もないでしょう。


400:デフォルトの名無しさん
08/02/07 18:13:43
URLリンク(scripts.web.fc2.com)

UWSCで書いたやつと同じものがPythonならどんな感じになるかなって作ってるわけで、
これを手助けしたから荒らされるなんて心配も無用。

一応目標はURLリンク(panda3d.org)使って3Dぐりぐりすることなわけで。
ああ、3Dぐりぐりに文字エンコードは関係ないですかそうですか・・・


401:デフォルトの名無しさん
08/02/07 18:53:06
>>399
だれもそんな心配してないよwww

402:デフォルトの名無しさん
08/02/07 20:21:55
>>398
やあ表示できたよありがとう。
DOSプロンプトにならちゃんと表示されるようになった。

src.split('<')とするのには気が付いたけどまた躓いてるし。

WingIDE無料版がそれなりに使える。
日本語表示はされないものの、文字コードはそのまま扱えてるし
プレーンテキストよりかなり楽チン。
エディタだけじゃなくShellまで漢字に非対応なのがちょっと残念。


403:デフォルトの名無しさん
08/02/07 22:17:26
流れがよくわからんだが、ようは、日本語のことを聞きたいわけね

404:デフォルトの名無しさん
08/02/08 00:59:25
なんとかHTML最後まで読んでスレッド表示できるとこまでいった
あとは制御を正しくやって投稿まで出来れば完成か。
丸二日かかる計算だけどここまでやってもまださっぱりだ。


405:デフォルトの名無しさん
08/02/08 01:03:02
COMなんて使うからだ

406:デフォルトの名無しさん
08/02/08 01:26:55
だからどこの小学校の宿題なのか書けよ

407:デフォルトの名無しさん
08/02/08 01:27:08
>>405
ちゃうちゃう。
COM部分はUTMSじゃなくてUWSCで既に作ってあった。
まあ漢字が表示されないとか言ってたけどそれはCOMに限った話じゃないし。

そういえばUTMSどうなったんだろ・・・


408:デフォルトの名無しさん
08/02/09 00:22:01
日本語を扱えないのはPython関係がASCIIフォントしかサポートしてないからで、
フォントをサポートした環境に対して出力すればそのまま表示された。
一番簡単な方法は、DOSプロンプトから.pyファイルを起動して実行し、DOSプロンプトにprint出力。
なまじPython実行環境が文字出力できちゃうもんだからコーディングが間違ってんのかと思ってしまう。

まあuでユニコード定義した文字じゃないと文字化けするけど。


409:デフォルトの名無しさん
08/02/09 00:29:27
文字コードとフォントがごっちゃになってないか?

410:デフォルトの名無しさん
08/02/09 00:55:22
>>409
なってないよ。

Pythonのシェルでユニコードマルチバイト文字をprintして0x9999とか表示されるのは
2バイト文字をサポートしてないからだよ。
ああ、これについては文字コードかな。
WingIDEのエディタとか内臓シェルで表示されないのは単純にフォントの問題。

それよりなんでLって人気あるんだろ。
実写版LだとLは自分の名前書いてキラに勝ったんだね。
僕もデスノートを贈られたとき、自分の名前書いて洗脳を解いたんだけどまあいいか。


411:デフォルトの名無しさん
08/02/09 01:55:36
なんか生半可な人が来ちゃったなあ

412:デフォルトの名無しさん
08/02/09 08:39:40
とりあえず、UTF-8とかCP932とか、ちゃんとしたコードセット名を使って説明
していただけないと、私のような初心者にはちんぷんかんぷんです ><

413:デフォルトの名無しさん
08/02/09 10:01:10
>>409
分けて考えられない人は、ごっちゃにしてない、としか答えられないと思う。

414:デフォルトの名無しさん
08/02/09 10:11:35
>>412
CP932は大げさでしょ。

ソースコード自身の文字コードを置いておくと、
基本的にはASCIIコードと16ビットユニコードなんじゃないの?
んでWindowsNT系、XPとかVistaとかの漢字は16ビットユニコードだから、
NT内部だけで処理する場合には文字をそのまま送信、受信できるし、
ネット上のものでもブラウザ経由なら自動的にエンコードされるから問題ない。

んでpythonやり始めてすぐは、
文字化けする環境のせいでうまくできてるんだか出来てないんだか分からないところでちょっとつまづく。
というのがすぐ上で僕が書き込んでた問題。

問題があるのは直接サーバーと通信したりして、いろんな文字コードのデータを
そのままで送受信する場合。
ほかには、日本語環境ならシフトJISで保存されたファイルへのアクセスでエンコードが必要になる。

あとは、現状で自動でエンコードかかったりするらしいので勘違いしてはまってしまったりするかも。


415:デフォルトの名無しさん
08/02/09 10:13:34
>>409
>>413
ごっちゃになってるとしか指摘できないのは分かってないからじゃないの?


416:デフォルトの名無しさん
08/02/09 10:24:23
16ビットユニコードって何?

417:デフォルトの名無しさん
08/02/09 11:17:16
>>416
UTF-16のことだね。
特徴は、半角英数なども16ビットで表現すること。
普通にユニコードと言えばこれのことだから16ビットって言わないだけ。
pythonでu指定するのもUTF-16だろう。
ただuと入れれば済んじゃってUTF-16って名前が出てこないんで逆に分かりにくいのかもね。

UTF-8は、半角英数が8ビットで、
見分け方は、半角英数が見えつつ、漢字1文字が%xxみたいな半角記号3文字に置き換わる。
URLで使ってて普段目にするからどんなのかは分かるでしょ。

アルファベット圏ではUTF-8だと互換性は高いしデータ量は少なくて済むし普及しちゃってるんだけど
日本語みたいなマルチバイト文字圏では互換性のあるコードと言えば、UTF-16。
2バイトで表現すればデータ量は少なくて済むしプログラムでも固定長だから扱いやすいし。

まあシフトJIS単一が一番扱いやすいけどね。
データ量が最小で表現できるし。
でも制約も大きくて、インターネットで国際化がデフォな現代には合わないんだな。
こんなとこで言うような話題じゃないけど、
とりあえず日本語対応してなさそうに見えるpythonには必要な話題と思ったから書いた。

まあ、ごっちゃになってないとか言ったけど用語とか適当だし言葉も適切じゃなかったりしたかもね。
ようは話が通じればいいんだ。


418:デフォルトの名無しさん
08/02/09 11:45:33
半角記号って何?

419:デフォルトの名無しさん
08/02/09 12:08:57
URL エンコードされた文字列のことなんじゃないか?

420:デフォルトの名無しさん
08/02/09 12:38:14
ucs4最強

421:デフォルトの名無しさん
08/02/09 12:49:58
>>417
UTF-16は固定長じゃないwww

422:デフォルトの名無しさん
08/02/09 12:59:35
UCS-2とは違うのだよUCS-2とは

423:デフォルトの名無しさん
08/02/09 13:21:57
【 課題 】
成績表のファイルを読み込み,合計点の上位20人だけを印刷する。20番目に同点者がいた場合は,同点者は全員印刷する(20人を超えることがある)。
【 用語 】
【 期限 】2月12日まで
【 Ver  】2.5.1
【 補足 】丸投げですが、よろしくお願いします。
自分でも多少やったのですがよくわからなくなりました。

424:デフォルトの名無しさん
08/02/09 13:24:20
成績表のファイルとやらの書式を言ってくれんとなんとも

425:デフォルトの名無しさん
08/02/09 13:24:55
プラットフォームは

426:デフォルトの名無しさん
08/02/09 13:29:54
外部表現なんか適材適所で好き好きでいいんだけどさ
UTF-16なんて実際どこで使われてるん?めちゃ失敗作だろあれだけ。
日本人だけどもUCS-2のままのがまだマシ。

427:デフォルトの名無しさん
08/02/09 13:45:35
>>423
それだけじゃ具体的なコードは提示できないけど
単に人間がやる場合(モデル)をかんがえればいいんだよ。

a. 成績表を目で追っていき一番点数の高いやつを見つけて印刷。
二位以下も同様にくり返す。
b. 成績表から個々の成績(名前と点数の組?)をそれぞれ一枚の紙切れに写していく。
それらを点数順に並び替える。上位から印刷。

他にもあるだろうけどaよかbのが単純。

428:423
08/02/09 13:45:39
即レスありがとうございます

成績表のファイルはこんな感じのtxtファイルです。
番号 国語 数学 英語
53001 30 45 96
53002 63 52 53
53003 71 80 99
53004 54 44 66
53005 65 91 75
53006 81 100 71

説明がわかりにくかったらいけないのであげときました
URLリンク(sakuratan.ddo.jp)

429:デフォルトの名無しさん
08/02/09 13:55:46
>>417
君がわかってない人である事は通じた


430:デフォルトの名無しさん
08/02/09 14:32:04
>428
適当に。

students = []
for line in open('test.txt'):
    name, kokugo, suugaku, eigo = line.split()
    point = int(kokugo) + int(suugaku) + int(eigo)
    students.append((point, name))

students.sort()

MAX = 20
recentpoint = -1
for (i, student) in enumerate(students[::-1]):
    point, name = student
    if (i+1 > MAX) and (point != recentpoint):
        break
    else:
        print i+1, name, point
        recentpoint = point

431:428
08/02/09 14:36:49
>>430
正常に動作しました。本当にありがとうございますm(_ _)m
これからこのプログラムを理解したいと思います。

432:デフォルトの名無しさん
08/02/09 14:57:43
sortメソッドに比較関数を渡してソートできるかを見る課題だと思った

433:デフォルトの名無しさん
08/02/09 15:20:18
>>429
じゃあどこまで分かってるのを分かってるって言うっての?

あんたが言いたいのはたとえば殺人罪だと初犯の罪状がこれこれで
何人殺せば死刑だけど年齢がいくつだとここまででで、さらに何条の何っていう
特例まで含めた法律を丸暗記してないと弁護士としては駄目なんじゃないのみたいな?

普通は死刑になりうるし懲役で20年くらい食らう程度に知ってれば十分なんじゃね?


434:デフォルトの名無しさん
08/02/09 15:23:59
わたしのために喧嘩しないで

435:デフォルトの名無しさん
08/02/09 15:50:35
大学入りたてでちょっと法律学んだ子が
法律事務所にずかずか入ってきて
法律とはこういうもんだと延々講釈を垂れる

ここを法律事務所に例えるのは少し無理があるがまあそんな感じ

436:デフォルトの名無しさん
08/02/09 16:02:57
それならば「普通は懲役になりうるし懲役で20年くらい食らう」と知っていることだけ
答えればいいのに…
知らないことを無理して答えるから恥をかく。

437:デフォルトの名無しさん
08/02/09 17:40:06
>>436
どこら辺に知らないことを知ったかぶりしてる部分があるんですか?
馬鹿?

>>435
いや、よその法律事務所の人は来なくていいから。
ああ、非常勤職員でしたか。たまには顔出してね。


438:デフォルトの名無しさん
08/02/09 18:51:44
内部表現が16ビットである事とUTF-16は全然別の話だから
それをごっちゃにしているのは馬鹿だと断定できる



439:デフォルトの名無しさん
08/02/09 18:54:47
>>437
指摘されてもわからないところが、救いようのないバカ。

440:デフォルトの名無しさん
08/02/09 19:05:24
>>426
>UTF-16なんて実際どこで使われてるん?

WindowsのAPIではUTF-16が使われている
つまり最も使われている。


>>438
UTF-16の16は16ビットの16なのに16ビットとUTF-16が全然別の話だと?

そういうことを言うから分からなくなるんだろ。この役立たずが。
大学院と言う名の病院でおとなしくしてろ。

>>439
文字は表示されればいいってことが分からないアホがなに言ってんの?
内心の美しさは思い込みで作られるって知ってる?


441:デフォルトの名無しさん
08/02/09 19:10:01
正確にはU"TF"じゃないけどな

442:デフォルトの名無しさん
08/02/09 19:10:50
サロゲートペア?

443:デフォルトの名無しさん
08/02/09 19:15:04
恥の上塗りってやつを久しぶりに見た。

444:デフォルトの名無しさん
08/02/09 19:15:13
>>440
あーあ、わざわざ上げちゃって。 バカは驚くほど侮蔑に弱いからな。www
お前の説明はデタラメだ。

445:デフォルトの名無しさん
08/02/09 19:18:32
え、UTF-16=UCS-2 だと思ってた

446:デフォルトの名無しさん
08/02/09 19:21:41
UTFは文字とコードのマッピングに関しては何も定義していない。

447:デフォルトの名無しさん
08/02/09 19:31:05
「半角」は、無いよな、いくらなんでもな・・・

448:デフォルトの名無しさん
08/02/09 19:45:25
>>441
無関係なことを言って混乱させるなボケ

>>444
大雑把なのを出鱈目だってさ。

後ろにwwwつけるほうがよっぽどデタラメなのが分からないVipperが。
早いところ治療しろよ。
精神病は治らないんだっけ
一応アスペルガーっていう病気らしいから調べて病院に行って来い。

>>447
半角じゃないならなんだ。全角ですかそうですか。

>>445
正確には知らんが、UTF-16とUCS-2はほぼ同じもの。
2001年3月に策定のUnicode3.1以前はUTF-16もなかったわけで、
今一番普及してるWindowsXPが登場直後のUTF-16を満足してるかわかんないから実質区別はないかも。

僕が勉強したのは完全16ビットのユニコードのころだったし文字の深いところまでやってるわけじゃないから
別に16ビット固定で全然困らないよ。


それを訳分からんやつが小難しい辞書を引っ張り出してきて「あれ?ちょっと違うんじゃね?」って
具体的には何も言わないくせにけちばっかりつけてきやがる。


449:デフォルトの名無しさん
08/02/09 19:49:59
サロゲートペアもExtension Bも知らないでここまで大口叩く奴は初めて見た。

450:デフォルトの名無しさん
08/02/09 19:51:57
>>449
俺知ってる。けど馬鹿に教えても無駄だから教えない。何のために知ってるって発言したの?自己主張ですか。じゃあ来なくていいよ。資源の無駄。


451:デフォルトの名無しさん
08/02/09 19:53:54
具体的に言わないのはわざとなのです。
他人の間違いを指摘して、正してあげるほど
親切な人ばかりじゃないのです。

ちなみに「ちょっと違う」わけではりません。


452:デフォルトの名無しさん
08/02/09 19:58:00
>>448には>>446の意味は一生理解できまい。

453:デフォルトの名無しさん
08/02/09 20:02:23
>>446
はいはいそうだね。

UTF-8とTUF-16を変換してもなんにもかわんないよね。


454:デフォルトの名無しさん
08/02/09 20:03:57
超大物釣り師が出現したのは、このスレですか?

455:デフォルトの名無しさん
08/02/09 20:06:29
>>448
デタラメを大雑把と主張する幸せ脳。wwww

> 半角じゃないならなんだ。全角ですかそうですか。
> 半角じゃないならなんだ。全角ですかそうですか。
> 半角じゃないならなんだ。全角ですかそうですか。
> 半角じゃないならなんだ。全角ですかそうですか。
> 半角じゃないならなんだ。全角ですかそうですか。
wwwww

> 正確には知らんが、UTF-16とUCS-2はほぼ同じもの。
必死でググッてきたようだな。「正確には知らんが」が笑わせてくれる。

> 2001年3月に策定のUnicode3.1以前はUTF-16もなかったわけで、
wwwww

456:デフォルトの名無しさん
08/02/09 20:06:31
>>451
文字コードを勝手に変換するようなスクリプト言語をそんな厳密な計算に使うわけないでしょ。

オートマチック車に乗ってるクセしていちいち1速2速3速ってレバー操作するんなら何のためにオートマチック車に乗ってんのかわかんないでしょ。
燃費を悪くするためですかそうですか。


457:デフォルトの名無しさん
08/02/09 20:09:29
いかん。上げてたせいで変なのが寄ってきた。


458:デフォルトの名無しさん
08/02/09 20:11:54
間違ってるよ、って教えてあげてる方々に質問です。
このひとって、もしかして、文字コードとフォントの区別がついてないひとだよね?
別の人が現れたわけじゃないよね?

459:デフォルトの名無しさん
08/02/09 21:26:07
別の人じゃありません。全部同じ人ですよ。

460:458
08/02/09 22:37:15
ありがとうございます。
最初の人は恥ずかしくてもう出てこれないな、と思ってたので…

461:デフォルトの名無しさん
08/02/09 23:12:22
教えて欲しい未熟な人と、教えてあげるやさしくて知識のある人のスレかと思ったけど
未熟な人をいじめてあざ笑ってストレス発散する場所だったんですね。
だから1年半経っても半分も埋まらないほど過疎ってたんだ。
新入りをいびって追い出すから。

まあ、どっかの相撲部屋みたいに殺してしまうわけじゃないからいいけど。


462:デフォルトの名無しさん
08/02/09 23:13:16
殺してしまうわけじゃないから良いスレですよ

463:デフォルトの名無しさん
08/02/09 23:18:37
いえ、未熟だと気がつかないばかりか、周りが未熟だと言い張るひとは
決して「教えて欲しい未熟な人」ではありません。


464:デフォルトの名無しさん
08/02/09 23:58:51
>>463
僕がここで質問して、まあ誰も教えてくれなかったけど解決して自分なりに結論を出して、
まあ質問が残ったままになるのも迷惑だろうしと書き込んだら、
いきなり人間的に未熟な人たちがケンカを売ってきたから応じただけですよ。

>>409とか>>411とか>>413とか
>421
>426
>429
>435
>436
>438
>439
>441
>443
>444
>446
>447
>449
>451
>452
>455
>460
>463

とか

一番最初に>>409がなんか勘違いしたところから始まってると思うよ。


465:デフォルトの名無しさん
08/02/09 23:59:59
まあ上げてる人を相手にしちゃいけないってことですよ

466:デフォルトの名無しさん
08/02/10 00:04:26
もう飽きた図ら


467:デフォルトの名無しさん
08/02/10 00:20:27
妄想から結論だすひとは、まぁ、最後はこんなもんですな。

468:デフォルトの名無しさん
08/02/10 00:21:08
> 僕がここで質問して、まあ誰も教えてくれなかったけど解決して自分なりに結論を出して、
> まあ質問が残ったままになるのも迷惑だろうしと書き込んだら、
デタラメが残るほうが1000万倍迷惑だ。

469:デフォルトの名無しさん
08/02/10 00:26:08
>>464
間違いを指摘したら「人間的に未熟な人」になるの?

470:デフォルトの名無しさん
08/02/10 00:29:55
嘘が残って困るから僕も反論してるのに

471:デフォルトの名無しさん
08/02/10 00:32:55
> 自分なりの結論
> 自分なりの結論
> 自分なりの結論
> 自分なりの結論
> 自分なりの結論
弱気になってきたな。wwww

472:デフォルトの名無しさん
08/02/10 00:33:57
反論なぞどこを探してもないわけだ。
あるのはタダのイヤイヤだけ。

473:デフォルトの名無しさん
08/02/10 00:34:00
だからCOMなんて使うからだろ。
その選択眼が全てを物語っている。

474:デフォルトの名無しさん
08/02/10 00:34:13
とりあえず言いたいのは日本語のフォントを選択させてくれれば日本語表示できるのに
英語フォントしか選択できないから日本語が表示できないってことなんだけど
カンケーネーだのそれは間違ってるだのウゼー


475:デフォルトの名無しさん
08/02/10 00:36:28
>>473
そうだね。
pythonなんてクソ言語を選択した僕の間違いだったね。
だけど、僕より先にpython使っててよく知ってるはずなのにその過ちに気が付かないあなたはもっと愚かですね。


476:デフォルトの名無しさん
08/02/10 00:36:47
だって、文字コードとフォントの区別がついてないんだもん。
(最初に戻る)

477:デフォルトの名無しさん
08/02/10 00:38:17
↓そこでPythonがクソだからいけないんだ~のやるおAA

478:デフォルトの名無しさん
08/02/10 00:41:18
おまけに内部実装と文字集合とコーデックの区別も付いていないと

479:デフォルトの名無しさん
08/02/10 00:42:25
>>478
内部なんか知るかよ。

逆コンパイルすると逮捕されるよ?


480:デフォルトの名無しさん
08/02/10 00:44:40
だからさっさとPythonなんかやめて、
フォントの指定を言語仕様に含んだ言語へ行けって・・・

481:デフォルトの名無しさん
08/02/10 00:46:24
>>480
だからフォントの指定を言語使用に含んだ言語がどれなのか教えてくれたらいけるんだってば。


482:デフォルトの名無しさん
08/02/10 00:52:49
つ"VB"

483:デフォルトの名無しさん
08/02/10 01:00:17
>>479
ヒント:オープンソース

484:デフォルトの名無しさん
08/02/10 07:51:37
俺のところには来るなw

485:デフォルトの名無しさん
08/02/10 15:26:48
久々にスレが延びてると思ったが
案の定バカが暴れてただけかorz


486:デフォルトの名無しさん
08/02/10 15:29:48
>>456
AT車でもバックするときはRにGear入れるだろ
お前はDのままでバックしないっつって喚いてる馬鹿


487:デフォルトの名無しさん
08/02/10 15:46:37
python3.0っていつ出んの?

488:デフォルトの名無しさん
08/02/10 16:10:05
>>487
URLリンク(www.python.org)

489:デフォルトの名無しさん
08/02/10 16:50:35
>>483
僕が使ってるWingIDEは有料なんだけどソースコードはただでゲットできるの?

>>482
いらね

>>486
わかんねーから教習所に通ってんのに、お前らはなんにも教えてくれない自動車教習所の教官。
へたっぴな運転を見てからかってる。

僕も脇をすり抜けたりしてからかってはいるが、教官が一緒に乗ってるから安心してやってるんだ。
失敗できるのは生徒である特権だからな。
と、突然リアルに話を振って見る。


490:デフォルトの名無しさん
08/02/10 16:55:50
わざわざageなくてもいいですよ

491:デフォルトの名無しさん
08/02/10 17:03:21
>>489
すげー被害妄想だな


492:デフォルトの名無しさん
08/02/10 21:28:53
>>489
教習所の教官は金貰ってやってる仕事だ。
俺らは自分のプログラミングの為に来てるついでに
気が向いた時にボランティアもやってるってだけ。

493:デフォルトの名無しさん
08/02/10 22:05:48
必死で考えた例え話なんだろうけど、低脳が考えただけ有って穴だらけでかなり笑えるな。

494:デフォルトの名無しさん
08/02/10 22:12:05
DOS 窓でスクリプトのエンコーディング指定されたファイルの
unicode 文字列が文字化けしないのは
印字するときにどーゆーワケか DOS 窓のエンコーディングにエンコードしてくれるからで
フォント関係ないと思うんですが
違うんですか?

495:デフォルトの名無しさん
08/02/10 22:28:01
いま暴れてる人は、フォントを指定すれば文字コードに関係なく
自分の意図した表示が得られると思っているのです。

496:デフォルトの名無しさん
08/02/10 22:29:34
>>489
お客さん、教習料が未納ですよ

497:デフォルトの名無しさん
08/02/10 23:06:30
>>494
フォントが関係ないのになんで表示されるんですか?
英語版Windowsでは表示されませんがなんで表示されないんですか?

なんでそういう出鱈目を吹聴して回るんですか?


498:デフォルトの名無しさん
08/02/10 23:28:41
時々、こういうヤツをどうにかして殺せないかと真剣に思う。

499:デフォルトの名無しさん
08/02/10 23:35:24
放置しとけば自滅する。

500:デフォルトの名無しさん
08/02/10 23:40:17
pythonWinではDOS窓のように漢字が表示されないなあ。


501:デフォルトの名無しさん
08/02/10 23:43:39
>>498-500
お前らまとめて富士の樹海ハイキング行ってこい

502:デフォルトの名無しさん
08/02/10 23:44:54
pythonWinの場合
>>> 'あいう'
'\x82\xa0\x82\xa2\x82\xa4'
>>> u'あいう'
u'\x82\xa0\x82\xa2\x82\xa4'

コマンドラインの場合
>>> 'あいう'
'\x82\xa0\x82\xa2\x82\xa4'
>>> u'あいう'
u'\u3042\u3044\u3046'


503:デフォルトの名無しさん
08/02/10 23:53:04
pythonWinの場合
>>> 'あいう'
'\x82\xa0\x82\xa2\x82\xa4'
>>> print 'あいう'
あいう
>>> u'あいう'
u'\x82\xa0\x82\xa2\x82\xa4'
>>> print u'あいう'
???¢??


コマンドラインの場合
>>> 'あいう'
'\x82\xa0\x82\xa2\x82\xa4'
>>> print 'あいう'

>>> u'あいう'
u'\u3042\u3044\u3046'
>>> print u'あいう'
あいう


504:デフォルトの名無しさん
08/02/10 23:54:15
ミス

コマンドラインの場合
>>> 'あいう'
'\x82\xa0\x82\xa2\x82\xa4'
>>> print 'あいう'
あいう
>>> u'あいう'
u'\u3042\u3044\u3046'
>>> print u'あいう'
あいう


505:デフォルトの名無しさん
08/02/10 23:57:12
これだけ耳の無い人も珍しいな

506:デフォルトの名無しさん
08/02/10 23:59:39
まだいたのか・・・

507:デフォルトの名無しさん
08/02/11 00:04:43
>>497
繰り返しますが
DOS 窓で unicode 文字列を印字するときは
勝手に DOS 窓のエンコーディングにエンコードされます
日本語版 Windows しか触ったことがないので分かりませんが
おそらく英語版の DOS 窓のエンコーディングは日本語表示できませんよね

508:デフォルトの名無しさん
08/02/11 00:13:41

お客様の中に子供の知育、中でも特に
「分けて考える」という概念を芽生えさせる手法について
詳しい方いらっしゃいませんか?



509:デフォルトの名無しさん
08/02/11 00:19:27
PhthonWinの場合の追加

>>> s = unicode('あいう','sjis')
>>> s
u'\u3042\u3044\u3046'
>>> print s
あいう


510:デフォルトの名無しさん
08/02/11 01:04:15
>>508
必要なのは発達障害児を支援する訓練を受けている人だろう。

511:デフォルトの名無しさん
08/02/11 01:05:01
みんな親切だな

512:デフォルトの名無しさん
08/02/11 01:45:59
おまえら日本語訳とか見てる?
ここ間違ってるんだが、何がどう間違ってるか分かる?
えらそうに説教たれてるんだから即答できるよな?
URLリンク(www.python.jp)


513:デフォルトの名無しさん
08/02/11 01:54:46
おまいは本当に論理的に物を考えられないんだな

514:デフォルトの名無しさん
08/02/11 02:15:04
>>512
訳が間違ってるなら、連絡すれば?
人手が足りないらしいし。

Pythonドキュメント翻訳プロジェクト
URLリンク(www.python.jp)

515:デフォルトの名無しさん
08/02/11 02:15:06
なんかネタスレにレスが大量に……と思ったら
達人タンじゃないか。
こんな所で何やってんの?
また、横着言って暴れてるのかね。

516:デフォルトの名無しさん
08/02/11 02:18:45
その筋では有名なのか?
引き取ってくれよ。

517:デフォルトの名無しさん
08/02/11 02:27:13
訳が間違ってるんじゃなくて説明が間違ってるだろ。
u指定した文字列のコードがぜんぜんユニコードじゃないのに気がつかなかったのかと。


518:デフォルトの名無しさん
08/02/11 02:35:57
IDLE 1.2.1 だと

>>> u'あいう'
u'\x82\xa0\x82\xa2\x82\xa4'
>>> unicode('あいう', 'cp932')
u'\u3042\u3044\u3046'

ってなるよ

519:デフォルトの名無しさん
08/02/11 02:37:57
なるけど、間違ってるよな。

だってユニコードじゃないんだもん。


オブジェクト的にはユニコード扱いでも、壊れたデータだからユニコードじゃない。


520:デフォルトの名無しさん
08/02/11 04:22:49
いや訳の間違い
URLリンク(docs.python.org)
元は 'äöü' だから気をきかせて 'あいう' に置き換えた
つもりで間違いを入れてしまったんだね

521:デフォルトの名無しさん
08/02/11 10:42:24
>>> u"abc"
u'abc'
>>> u"あいう"
u'\u3042\u3044\u3046'
>>> str(u"あいう")
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-2: ordinal not in range(128)
>>> u"あいう".encode('utf-8')
'\xe3\x81\x82\xe3\x81\x84\xe3\x81\x86'
>>> unicode('\xe3\x81\x82\xe3\x81\x84\xe3\x81\x86', 'utf-8')
u'\u3042\u3044\u3046'

522:デフォルトの名無しさん
08/02/11 11:38:34
MLのログを見るとちょうど1年前に>>512と同じ指摘されて対応するようなことを言ってるね。
僕は新参者でよく知らなかったけど、u指定で自動的にユニコードにエンコードされるのは
あのドキュメントのバージョンあたりからで、それ以前ならあの訳の結果で正しかったらしい。
他の製品とで動作が異なるのは、仕様を引きずったかどうかだけっぽいな。

まあ最初の仕様がまずすぎだと思うけど。
äöüってのが、シフトJISでの半角カナの位置づけで、
そのままのコードでユニコードになるんだろうから言語仕様で問題にはならなかったんだろう。
・・・違うな。
ただデフォがunicodeなだけだ。

しかし、せっかくインタプリタがあるのに、画面から入力したものとファイルに保存したものとで動作が異なるようじゃ当てにならんな。
せめて画面とファイルの文字コードを統一できればいいけど、utf-8以外で保存してもエラーになるし。
最新版のコマンドラインとutf-8のファイル使えばちゃんと動くから僕はいいけどみんなはいろいろ衝突しちゃうだろうなあ。


523:デフォルトの名無しさん
08/02/11 12:10:07
>>522
> utf-8以外で保存してもエラーになるし。 

#-*- coding: sjis -*-
とか付けてる?

524:デフォルトの名無しさん
08/02/11 13:22:04
まだやってんのか

525:デフォルトの名無しさん
08/02/11 13:24:53
>>523
ああ、メモ帳で保存形式ASCIIでシフトJIS指定したらできた。
全部表示される。
# encoding: sjis
print unicode('あいう', 'sjis')
print u'あいう'
print 'あいう'

utf-8ならコード指定なしでできちゃったのは、先頭に強制でフラグ?が入るからなんだね。
メモ帳じゃどのコードでもまったく同じに見えちゃって気がつかない。
16ビットのユニコードは指定方法が分からないし使えるとは思えないけど・・・

# encoding: utf-8
print unicode('あいう', 'utf-8')
print u'あいう'
print 'あいう' #←文字化け

sjisで保存するとユニコードにしなくても表示されちゃうから間違っても気がつかないね。
だからやっぱりutf-8で保存するべきだろう。


526:デフォルトの名無しさん
08/02/11 13:30:49
やれやれ、coding指定を知らない人だったのか。これで終了かな。

527:デフォルトの名無しさん
08/02/11 13:36:54
coding指定知らなかったけど別に間違ってもないし。


528:デフォルトの名無しさん
08/02/11 14:06:27
>>527
まあ、Rubyでも使ってろや

529:デフォルトの名無しさん
08/02/11 14:27:48
>>408-409
文字コードのお話はこれが最初。

延々やりあってる間に確かにいろいろ間違ってはいたけど、pythonで日本語表示することについては間違ってないから。
それ以前はまったく分かってなかったけど。

間違いを自分で振り返ると
>>417
>漢字1文字が%xxみたいな半角記号3文字に
バイト数に関しては合ってるが、見た目ぜんぜん違ってた。
正直、URLエンコード=utf-8と思ってた。

>>440
>WindowsのAPIではUTF-16が使われている
Windowsで使われてるけどAPIはシフトJISだっけね。

>>479
>逆コンパイルすると逮捕されるよ?
これは昔の話

ああ、あと、DOS窓は16ビットUNICODE対応だと思ってたっけ。
実際UNICODEファイル名、UNICODEテキストが表示されるし。
コマンドも含めてDOS窓だといってしまえばUNICODE対応と言って差し支えないが。

>>494
この人は正しかったようだが「フォントは関係ない」とか余計な事言うから。


それ以外について指摘すべきところはないな。


530:デフォルトの名無しさん
08/02/11 14:31:14
>>529
>それ以外について指摘すべきところはないな。
人間性について

531:デフォルトの名無しさん
08/02/11 14:51:59
半端な知識でつじつま合わせは恥の上塗り。wwww

532:デフォルトの名無しさん
08/02/11 15:09:13
負けず嫌いな人をいじってると、いつまでたっても終わらないよ

533:デフォルトの名無しさん
08/02/11 15:13:52
ム板、マ板には長くいるが、こんなアホども見たことない。















こともない。


534:デフォルトの名無しさん
08/02/11 15:14:27
>>529でサマリまで出してきたしもういいじゃん
これ以上やると突っついてる方がバカっぽい

535:デフォルトの名無しさん
08/02/11 15:21:43
>>529を読む限りではそれほどの馬鹿でもないと思うんだが、変に自信満々な芸風を改めて
くれないと結構鬱陶しがられるだろうな。

536:デフォルトの名無しさん
08/02/11 16:04:39
なんでみんな釣りの相手するのが好きなのはなぜ?
暇なの?

537:デフォルトの名無しさん
08/02/11 16:18:55
釣るよりも釣られたい
愛されるより愛したい

538:デフォルトの名無しさん
08/02/11 16:30:08
あぁなるほど、そういう事でしたか・・・失礼しました。
以前多少かじった程度なのでこの際に少し弄ってみることにします。

539:デフォルトの名無しさん
08/02/11 18:51:44
結局ここまできて、文字コードとフォントを分けて考える事は出来なかったわけだ。

540:デフォルトの名無しさん
08/02/11 19:17:59
切り離しちゃったら文字が表示されなくなっちゃう品

541:デフォルトの名無しさん
08/02/11 19:18:30
>>539
そんなに分けたかったらフォント削除しやがれ

542:デフォルトの名無しさん
08/02/11 19:30:18
>>539
複数のレイヤーに分離して抽象化する事について、理解できない人は案外多いもんだよ。

543:デフォルトの名無しさん
08/02/11 20:20:02
まぁ気持ちはわかるな。
いろいろ気持ち悪いから、utf-8で入力やprintがすんなりできそうな対話窓とか以前探したんだけど、
いまいちしっくり来るのが無かった。

544:デフォルトの名無しさん
08/02/11 20:53:06
結局、内部と外部の境界を意識して
* 内部はunicodeに統一
* 入力はunicodeにデコード
* 出力はunicodeからエンコード
ってやるのが妥当なんじゃない?

545:デフォルトの名無しさん
08/02/11 21:01:02
>>543
Poderosaとか、TeraTermとか、puttyとかあるじゃん

546:デフォルトの名無しさん
08/02/11 21:09:44
UNICODEがそのまま表示できるターミナルでも
インタプリタでの出力は0xhogeになってしまうのはなぜ?


547:デフォルトの名無しさん
08/02/11 21:11:52
Pythonに対応したフォントが入ってないからだよ。

548:デフォルトの名無しさん
08/02/11 21:22:33
新しいギャグが生まれました。

549:デフォルトの名無しさん
08/02/12 00:28:37
「うちではちゃんと表示できるよ」派

550:デフォルトの名無しさん
08/02/15 18:36:44
>>503
>>504
>>509
>>525

さらに追加
WingIDEで日本語表示した場合。

>>> 'あいう'
'\xe3\x81\x82\xe3\x81\x84\xe3\x81\x86'
>>> print 'あいう'
縺ゅ>縺・
>>> u'あいう'
u'\xe3\x81\x82\xe3\x81\x84\xe3\x81\x86'
>>> print u'あいう'
Traceback (most recent call last):
File "<string>", line 1, in <string>
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-8: ordinal not in range(128)

Gui板はPythonWinもWingIDEも自動ユニコードにならないが、
とりあえず日本語表示できた。

>>543
WingIDEがutf-8で入力、出力はユニコードもシフトJISもいけて
その上Windowsと同じでソースコードはシフトJIS、ユニコード両方、UTF-8全部いけちゃうのは知ってた?


551:デフォルトの名無しさん
08/02/15 18:41:56
おっと早とちり。
出力はシフトJISだけか・・・
入力はutf-8なのになあ・・・

>>> unicode('あいう','utf-8')
u'\u3042\u3044\u3046'
>>> print unicode('あいう','utf-8')
Traceback (most recent call last):
File "<string>", line 1, in <string>
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-2: ordinal not in range(128)

>>> print unicode('あいう','utf-8').encode('sjis')
あいう
>>> print unicode('あいう','utf-8').encode('utf-8')
縺ゅ>縺・


552:デフォルトの名無しさん
08/02/15 20:29:04
>>550
知らなかったす。python用IDEみたいですね。
しかし対話でutf-8をスムースに使いたいのは、主にIPythonだったりするんで…。


553:デフォルトの名無しさん
08/02/18 06:45:59
>>30
>2chの任意のスレを複数登録・管理し、有益な情報が投稿されたときのみ通知、

これって簡単?

554:デフォルトの名無しさん
08/02/18 06:52:47
>>553
有益判定が大変。


555:デフォルトの名無しさん
08/02/18 06:55:02
>>553
多分これは除外不可能
スレリンク(tvd板:901-907番)


556:デフォルトの名無しさん
08/02/18 12:25:58
一見すれ違いかと思ったが

スレタイ「エジソンの母」

896の主張「エジソンは天才」

896の主張「天才が世のため人のためになるかならないのか」

901の主張「白(青)LEDの実用化は天才的かつ人のためにもなった例」

902(=901)の自慢話

903(=901)の自慢話(自演?)

904ネタ

905雑談

906スレ本来の流れにもどる?

907(906の自演)


557:デフォルトの名無しさん
08/02/18 12:27:48
896~901くらいまでは
辛うじてスレの主旨に合ってるが
それ以降は糞レス

ただ、いずれにせよ漏れにとっては全部無益だった


558:デフォルトの名無しさん
08/02/18 12:29:05
>>553
「何も通知しないプログラム」を作れば、ほぼ仕様に適合する。

559:デフォルトの名無しさん
08/02/19 07:12:13
>>555
俺には、スレ全部が無益だ

560:デフォルトの名無しさん
08/02/24 10:25:44
>>553
できた

print "Hello World."

561:デフォルトの名無しさん
08/02/24 11:52:09
妹に一緒にお風呂に入ろうと誘われたんですがどうすればいいですか?

562:デフォルトの名無しさん
08/02/24 11:57:44
>>561
さっさと入って来いこの幸せもん。

すみずみまで丁寧に洗ってやるんだぞ。


563:デフォルトの名無しさん
08/02/26 15:12:56
PILを使って画像を縮小はできたんだけど
フォルダの中の複数の画像をまとめて縮小ってどうやりますか?

>>> import Image
>>> snow = Image.open(r"C:\pyphot\snow.jpg")
>>> snow.thumbnail((200,200),Image.ANTIALIAS)
>>> snow.save(r"C:\pyphot\snow_resize.jpg")

これで1枚は出来たんだけど応用が利かない俺orz

for文使うとは思うんだけど…
教えて偉い人

564:デフォルトの名無しさん
08/02/26 15:30:39
>>563
>フォルダの中の複数の画像をまとめて縮小

この一言を実行するために必要な作業を、できるだけ細かく分けて考えてみな。
そして、リストにして書き出してみな。
まず日本語で書く。
書いたらここに貼り付ける。
「コンピュータの気持ちになる」ことが肝心。

565:563
08/02/26 15:41:28
・フォルダを探す
・フォルダのファイルを1つ読む
・そのファイルを縮小
・そのファイルをセーブ
・次のファイルを読む
・次のファイルを縮小
・次のファイルをセーブ

こんな感じですか?

566:デフォルトの名無しさん
08/02/26 15:46:34
for f in os.listdir(d):
    path = os.path.join(d, f)
    # ...

567:デフォルトの名無しさん
08/02/26 15:50:09
for path in glob.glob(r"C:\pyphot\*.jpg"):
 # ...

568:デフォルトの名無しさん
08/02/26 15:59:20
>>563
その質問のために「画像の縮小」という話題から入るところに、応用力の無さを感じる。
もっと抽象的に考える習慣を付けると良いのではないかな。

569:デフォルトの名無しさん
08/02/26 16:08:50
>>565
次は、そのリストを最初から順番に実行するスクリプトを作ってみ。
もし行き詰まったら、リストの項目をさらに細かな処理に分けてみるとよいよ。

570:563
08/02/26 16:29:57
>>568
抽象的ですか…

>>567を使って
for path in glob.glob(r"C:\pyphot\*.jpg"):
    for i in path:
        i.thumbnail((200,200),Image.ANTIALIAS)
        i.save(r"C:\pyphot\i_resize.jpg")

こんな感じですかね?




571:デフォルトの名無しさん
08/02/26 16:33:11
動かないだろそれ・・・

572:デフォルトの名無しさん
08/02/26 16:35:46
動かざること山の如し

573:563
08/02/26 16:35:53
あ、間違い
for path in glob.glob(r"C:\pyphot\*.jpg"):
    for i in path:
        i.thumbnail((200,200),Image.ANTIALIAS)
        i.save(r"C:\pyphot\resize.%s") % i

これでどうですか? 


574:デフォルトの名無しさん
08/02/26 16:37:42
動くようになってから提出な

575:デフォルトの名無しさん
08/02/26 16:39:14
ここに張る前にインタラクティブシェルとかに張って試せよ。

576:563
08/02/26 16:40:34
>>574
>>575
すみません
了解しました 

577:hint
08/02/26 17:19:32
1. glob.globが返すのは何か
2. import Imageがなくなってる
3. i.save(r"C:\pyphot\resize.%s") % i は文法的におかしくて、i.save(r"C:\pyphot\resize.%s" % i)としないといけない、(でも、コレもなんか変)

578:563
08/02/26 17:32:15
import glob
for path in glob.glob(r"C:\pyphot\*.jpg"):
  import Image
  r = Image.open(path)
  r.thumbnail((200,200),Image.ANTIALIAS)
  r.save(path)

できましたけど、上書きされる方法しか思いつかなかったorz
別に出力させたい時はどうしたらいいんでしょうか?

579:デフォルトの名無しさん
08/02/26 17:33:47
saveするときファイル名を変えればいい

580:デフォルトの名無しさん
08/02/26 17:34:05
ファイル名を変えればいいんじゃない?ってとこまで考えた?

581:デフォルトの名無しさん
08/02/26 17:40:21
ココなんて育成ゲーム?

582:563
08/02/26 18:21:52
import glob
for path in glob.glob(r"C:\pyphot\*.jpg"):
  import Image
  r = Image.open(path)
  r.thumbnail((200,200),Image.ANTIALIAS)
  path = path[:10] + "re" + path[10:]
  r.save(path)

できました!
スレ汚しすまそ


583:デフォルトの名無しさん
08/02/26 18:44:06
長さ決め打ちより os.path の basename, dirname, splitext
あたりを使ったほうが良いよ

584:デフォルトの名無しさん
08/02/26 21:12:41
なぜglobモジュールに頼るのだろうか。
reとosで事足りる気がするが

585:563
08/02/26 22:20:44
>>583
>>584
勉強不足で申し訳ないです…


586:デフォルトの名無しさん
08/02/26 22:41:24
584は正規表現大好きなPerl由来のオールドタイプ。

587:デフォルトの名無しさん
08/02/26 22:52:36
>>584
一般論として専用に設計されたものがあるなら、汎用品を使って再発明しないほうが良い

588:デフォルトの名無しさん
08/02/26 23:14:37
globだとUnicodeファイル名が来たらアウトじゃね
os.listdirで列挙してreで絞込みのほうがいいと思うんだが

589:デフォルトの名無しさん
08/02/26 23:19:28
>>587
文字コードの絡みで問題ないようにするには
メソッドじゃなくてreできちんと処理すべきだと思うんだ。
日本語ファイル名が0なら必要ないけど。

590:563
08/02/26 23:35:51
たびたびすみません
勉強の為にどなたか書き直してもらえませんか?

591:デフォルトの名無しさん
08/02/26 23:55:17
コレで十分

import glob
import Image

dir = r"C:\pyphot\"

for path in glob.glob(dir+"*.jpg"):
  r = Image.open(path)
  r.thumbnail((200,200),Image.ANTIALIAS)
  path = path[:len(dir)] + "re" + path[len(dir):]
  r.save(path)

592:デフォルトの名無しさん
08/02/27 00:13:22
import os
import os.path
import Image

dn = r"C:\pyphot\"

for fn in os.listdir(dn):
 if fn.lower().endswith(".jpg") and os.path.isfile(fn):
  r = Image.open(fn)
  r.thumbnail((200,200), Image.ANTIALIAS)
  os.rename(fn, fn + ".old")
  r.save(fn)

593:デフォルトの名無しさん
08/02/27 02:55:29
import re, os, Image

re_file = re.compile(r'(?i)(.*)(\.jpg|\.gif|\.png|\.bmp)$')
thumb = '-thumb'

for fn in os.listdir('.'):
 m = re_file.match(fn)
 if m and os.path.isfile(fn) and not m.group(1).endswith(thumb):
   r = Image.open(fn)
   r.thumbnail((200,200), Image.ANTIALIAS)
   fn_new = m.group(1) + thumb + m.group(2)
   print fn, '->', fn_new
   r.save(fn_new)


594:デフォルトの名無しさん
08/02/27 02:58:36
>>> dirname, filename = os.path.split("c:\\test\\foo.jpg")
>>> filename, ext = os.path.splitext(filename)
>>> dirname, filename, ext
('c:\\test', 'foo', '.jpg')

この辺りも使うとスマートなんジャマイカ

595:デフォルトの名無しさん
08/02/27 03:22:54
このスレも自演厨が棲息するようになったのか

596:デフォルトの名無しさん
08/02/27 03:31:35
>>594
うーん、あんま変わんなかったような。まぁ練習ということで。

import re, os, Image

dirname = u'.'
exts = ('.jpg', '.gif', '.png', '.bmp')
suffix = u'-thumb'

for fn in os.listdir(dirname):
 filename = os.path.join(dirname, fn)
 basename, ext = os.path.splitext(fn)
 if ext.lower() in exts \
     and os.path.isfile(filename) \
     and not basename.endswith(suffix):
   r = Image.open(filename)
   r.thumbnail((200,200), Image.ANTIALIAS)
   newfile = os.path.join(dirname, basename + suffix + ext)
   print fn, '->', newfile
   r.save(newfile)


597:デフォルトの名無しさん
08/02/27 05:25:34
ファイルシステムの文字コードは考えなくても大丈夫?

598:デフォルトの名無しさん
08/02/27 08:51:16
os.listdirにUNICODE文字列を渡しているならOK

あとどうせやるなら差分なりポイントだけ貼ってくれよ
間違い探しなんか誰もしたくないだろう

599:デフォルトの名無しさん
08/02/27 10:22:54
誰もユニコード指定してないから大丈夫なのかなと思ったんだ。

600:デフォルトの名無しさん
08/02/27 11:40:06
きっと Python 3000 なんですよw

601:デフォルトの名無しさん
08/02/27 13:27:37
ファイル名にマルチバイト文字列を使うのを許されるのは中学生まで

602:563
08/02/27 15:00:26
>>591
勉強になります
ありがとうございます

>>592
if fn.lower().endswith(".jpg") and os.path.isfile(fn):
がちょっと解りにくかったですが理解しました
ありがとうございます

>>593
正規表現は勉強不足ですorz
print fn, '->', fn_new ←これいいですね

>>594
なるほど
勉強になります

>>596
ファイル名分解した方がよさげですね



GUI使って便利に出来たらいいなぁ なんて
思ってますが、先は長そうです

みなさん、ありがとうございました

603:デフォルトの名無しさん
08/02/27 18:19:28
始末書.docを送ってくる30代の部下が許せなくなってきました

604:デフォルトの名無しさん
08/02/27 18:31:19
そうですか

605:デフォルトの名無しさん
08/02/27 18:55:15
企画書.xlsを送ってくる20代前半美人OLはどうでしょう。

606:デフォルトの名無しさん
08/02/27 18:59:15
ファイル名一覧.pptは、ちょっとめまいがした。

607:デフォルトの名無しさん
08/02/27 19:11:31
あそこ.bmpはいかが?

608:デフォルトの名無しさん
08/02/27 19:16:12
>>607
無圧縮ならOK

609:デフォルトの名無しさん
08/03/07 23:01:09
すみません。
宿題というほどではないのですが、
Pythonで2chのdatファイルを集めるプログラムを作成しています。
しかし、通信時間を設定していないせいか、何件かdatファイルをダウンロードしたら、
それ以降404エラーばかりになってしまいます。
そこで、一件獲得したら10秒待つようにしたいのですが、
どうしたらよろしいでしょうか?
宜しくお願いいたします。

610:デフォルトの名無しさん
08/03/07 23:07:22
>>609
import time
time.sleep(10)

611:609
08/03/07 23:09:44
>>610
マジサンクス!!
すごく助かりました。

612:デフォルトの名無しさん
08/03/09 08:47:05
>>611
更新をチェックして新規と更新のあった分だけをダウンロードしろよ?


613:デフォルトの名無しさん
08/03/29 15:27:50
ほしゅ

614:デフォルトの名無しさん
08/03/30 12:24:53
age

615:デフォルトの名無しさん
08/04/13 18:48:34
data = re.sub("[.*?]", temp, data)

『.』 を弾くにはどうしたら良いでしょうか?

616:デフォルトの名無しさん
08/04/13 19:50:45
>>615
\.

617:デフォルトの名無しさん
08/04/13 20:11:32
実際のスクリプトは何をしたいんだ?
[]の中じゃ、.*?とかは「その文字そのもの」を表して、
任意の文字とか最短マッチとかにならないんだが。

import re
data = 'a.b'
temp ='-'
data = re.sub("[.*?]", temp, data)
print data

結果
a-b

618:デフォルトの名無しさん
08/04/29 22:59:21
宿題じゃなくてスレチかもしれませんが、PythonでTcl
構文を解釈するモジュールなんてないですか?


619:デフォルトの名無しさん
08/04/29 23:08:27
SimpleParseでごにょごにょやればいいのでは

620:618
08/04/29 23:21:21
それは1から実装するのとあまりかわらなさげ。
至れり尽くせり的なものがあるといいのですが。

621:デフォルトの名無しさん
08/04/29 23:28:36
URLリンク(www.google.com)

622:618
08/04/30 00:27:48
tcl2pyみてみる。サンクス。

623:デフォルトの名無しさん
08/05/06 13:56:32
ニュートン法を使った平方根計算を作りたいのですが、例えば
Nの平方根を求める。初期値 a0、許容誤差 epsとして

def my_sqrt(n, a0, eps):
x = a0
new_x = 0.5 * ( x + n/x)
if abs(new_x -x) < eps:
# print 'In if abs statement:', new_x
return new_x
else:
my_sqrt(n, new_x, eps)

>>> my_sqrt(5.0, 2.0, 1.e-5)
# 5の平方根を初期値2から求める。誤差1.e-5になったら終了。
としても、returnで値が帰ってこないんですがなぜでしょうか?
#でコメントアウトしたprint文は(コメントを取ると)出力されるので、
再帰計算中に、許容誤差範囲に収束しないという事ではなさそうです。

624:デフォルトの名無しさん
08/05/06 13:59:31
>>623
最後の行に return が要るんじゃね?

625:デフォルトの名無しさん
08/05/06 14:04:34
>>624
return my_sqrt(n, new_x,eps)でうまくいきました…ありがとうございました。
再帰で帰ってきた値を、さらに返さないといけないって事ですね。

626:デフォルトの名無しさん
08/06/06 03:19:29
【 課題 】
キュー構造を実現するqueクラスとその確認コードを含むque.pyを作成せよ
queクラスは以下のメソッドを含む事。
def enque( data )
#値を受け取り、enque動作(待ち追加)を行う。
def deque()
#deque動作(待ち解消)を行い、値を返す。
def __str__()
#str()やprintで用いられる特殊メソッド。
#自分を表す文字列表現(ここでは内部値のカンマ区切りとする)を返す。


以下のコードを実行し、何が起きるかを理解せよ。
#! /usr/bin/python

import Tkinter as Tk
la = Tk.Label(None, text='Hello World!', font=('Times', '18'))
la.pack()
la.mainloop()


先のプログラムを書き換え、文字色と背景色を変更せよ。
文字色は白(#FFFFFF)、背景色は黒(#000000)とする。


「Hello World!」の表示を2つ並べたウインドウを表示せよ。
複数並べるには、親となるフレームを用意し、そこに配置すれば良い。


量が多いですがお願いします。


627:デフォルトの名無しさん
08/06/06 06:39:26
>>626
他スレで同じ質問して既に回答例を出してもらってるじゃん。

628:デフォルトの名無しさん
08/06/06 08:04:45
> 以下のコードを実行し、何が起きるかを理解せよ。

これは人に聞くもんじゃないだろ・・・

629:デフォルトの名無しさん
08/06/06 22:26:45
述べよ、ならともかく理解は他人にはどうこうできないなw

630:デフォルトの名無しさん
08/06/06 23:53:07
よし親切な俺が代わりに理解してやる

631:デフォルトの名無しさん
08/06/06 23:54:37
俺も。
理解するだけだけどな。

632:デフォルトの名無しさん
08/06/07 00:26:57
おれも理解できた

633:デフォルトの名無しさん
08/06/07 00:37:13
そういう問題は典型的なあれだな

レポート提出したあとに口頭諮問がある
そこでしどろもどろになったら終わり

悪いことは言わんから課題は自分でやっとけ


634:デフォルトの名無しさん
08/06/07 07:35:34
>>626

la を l1 とか書くと可読性が著しく低下することを理解

635:デフォルトの名無しさん
08/06/07 13:10:08
すいません、おれも理解してもらっていいですか?

636:デフォルトの名無しさん
08/06/07 14:05:19
お断りします。

637:デフォルトの名無しさん
08/06/07 14:08:55
      ハ,,ハ
     ( ゚ω゚ )  お断りします
    /    \
  ((⊂  )   ノ\つ))
     (_⌒ヽ
      ヽ ヘ }
 ε≡Ξ ノノ `J

638:デフォルトの名無しさん
08/06/07 14:19:16
男割りします。

639:デフォルトの名無しさん
08/06/07 14:21:14
いやん割らないで

640:デフォルトの名無しさん
08/06/09 20:15:06
【 課題 】
指定したフォルダの中身をフォルダの構成などを含めて完全にバックアップするソフトを作成すること。

尚、バックアップファイルには以下の機能を持つようにすること。

・ 対象ファイルや除外ファイルを指定できるような
仕組みを持つこと。
・ バックアップ経過のログを作成すること。
ログにはバックアップ処理の実行時間を出力すること。

また、既にあるフォルダが指定された場合の対処についてもそれぞれ考慮して
機能の実装を行うこと。


作業に余裕のある人は以下の機能を追加すること。

・バックアップしたファイルを圧縮する仕組みの追加。
・プログラムが常駐する仕組みの追加。

【 用語 】
【 期限 】6月13日まで
【 Ver  】2.5.1
【 補足 】丸投げです。
始めたばかりでまったくわかりませんでした。
なにとぞよろしくお願い致します。

641:デフォルトの名無しさん
08/06/10 03:10:52
同じく初級者が>>640を作ってみました。
へたれコードで申し訳ありません。
ご指摘、ご批判お願いします。
URLリンク(kansai2channeler.hp.infoseek.co.jp)

642:デフォルトの名無しさん
08/06/10 04:10:15
いただきました
ありがとうございます

643:デフォルトの名無しさん
08/06/12 23:20:10
作成日が4日前より古いファイルを
どうこうするプログラムを作りたいのですが
日付の比較がわかりません。
変数nowをシリアル値に変換しればできるのでしょうが
何か違う気がします。
シンプルに比較できないでしょうか?
ご教授下さいお願いします。

now=datetime.datetime.today()
prv=now-datetime.timedelta(days=-4)

t1=os.path.getctime("c:/hoge.txt")

if prv>t1:←ここ
print "ok"




644:デフォルトの名無しさん
08/06/12 23:29:08
prv>datetime.datetime.fromtimestamp(t1)
あとnow-datetime.timedelta(days=-4)だと4日後になるよ(-はどっちか)

645:デフォルトの名無しさん
08/06/13 02:41:04
find だろ


646:デフォルトの名無しさん
08/06/13 03:35:44
質問です。
直線を表示するコンポーネントを作成せよ。
【 用語 】
【 期限 】6月14日まで
【 Ver  】2.5.1
【 補足 】丸投げです。
javaで書くとこんな感じです↓
import java.awt.Graphics;
import javax.swing.JComponent;
import javax.swing.JFrame;
public class LinesSample extends JComponent {
protected void paintComponent(Graphics g) {
g.clearRect(0, 0, getWidth(), getHeight());

// (10, 100) から (200, 100) に線を引く
g.drawLine(10, 100, 200, 100);

// (100, 10) -> (100, 200) に線を引く
g.drawLine(100, 10, 100, 200);

// (30, 120) -> (180, 20) に線を引く
g.drawLine(30, 120, 180, 20);
}
public static void main(String[] args) {
JFrame frame = new JFrame("lines sample");
frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);

frame.getContentPane().add(new LinesSample());
frame.setSize(250, 250);
frame.setVisible(true);
}
}


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