1 名前:デフォルトの名無しさん mailto:sage [2007/03/14(水) 22:54:12 ] "The duct tape of the Internet" こと、Perlについての質問箱です。 "There's more than one way to do it" ということで、Perlの奥深さについて皆で語り合い、追求してまいりましょう。 CGIについての質問は板違いです。WEBプログラミング板でどうぞ。 CGIとPerlの区別がつかない人もWEBプログラミング板に行ってください。 (WEBプログラミング板 pc8.2ch.net/php/ ) CGIの質問は答えがPerlと全然関係ない話に帰着する場合が多かったりするのでWEBプログラミング板に行って聞いたほうが得ですよ。 このスレでは(CGI以外の)純粋にPerlのみに関係する質問を取り扱っていこうと思います。 スレ違いの質問にはスルーか、速やかな誘導をお願いします。 www.perl.org/get.html ● 2006/12/21現在の最新版: 5.8.8 ● 2006/12/21現在の開発版: 5.9.3 前スレ Perlについての質問箱 29箱目 pc11.2ch.net/test/read.cgi/tech/1166708139/ リンク集は>>2-3 過去スレは>>4
339 名前:デフォルトの名無しさん mailto:sage [2007/04/23(月) 00:35:06 ] 括弧閉じ忘れでごめんなさいorz >>337 さんのスクリプトを実行したところ、文字化けしませんでした。 また、from_toする前でも、ファイルにリダイレクトして、 そのファイルをエディタで開いても同様に文字化けしていませんでした。 しかし、サーバに持って行ってブラウザに結果を出すと文字化けしてしまいます。 エディタはUTF-8に対応していて、Perlスクリプトもutf-8で保存して、 use utf8; use open ":utf8"; use open ":std";して、 print "Content-type: text/html; charset=utf-8\n\n"; いるのですが、 >>337 さんのものでprint $dec;でもprint $str;でも駄目(文字化け)でした。 環境はWin XP SP2 + IE7、[表示]-[エンコード]でもUTF-8であることを確認しているのですが。。 。 度々で申し訳ないのですが、他に何か怪しい箇所がありますでしょうか?
340 名前:デフォルトの名無しさん mailto:sage [2007/04/23(月) 00:49:03 ] #!/usr/bin/perl my $str = '%E8%B3%AA%E5%95%8F'; (my $dec = $str) =~ s/%([a-f\d]{2})/pack 'H2', $1/egi; print "Content-Type: text/plainl; charset=utf-8\n\n"; print $dec; __END__ とりあえず手元だとこれで動いてる。まずは問題の発生する最小限のコードまで切り詰めてみ?
341 名前:337 mailto:sage [2007/04/23(月) 01:17:20 ] ありがとうございました!解決しました。 use open ":std";が余計でした(よく分からないのに「おまじない」で書くのは駄目でしたね)。 問題のスクリプトから上記を除いて、かつ、 自分で作って読んでいるモジュールからも上記を除きました。 本当にありがとうございます!
342 名前:デフォルトの名無しさん mailto:sage [2007/04/23(月) 01:18:56 ] 自分(↑)は>>337 さんでなくって>>335 でした。お目汚しでごめんなさい。 標準入出力を使わないなら、use open ":std";等は確かに不要でした。
343 名前:335 mailto:sage [2007/04/23(月) 03:15:36 ] 事後報告がてら・・・ use open ":std";を外せばアンエスケープで文字化けしないものの、 今度は後続処理でUTF-8な文字を処理できないという問題がありました。 結局、以下のサイトを参照して、 ttp://naoya.dyndns.org/~naoya/mt/archives/000611.html use open ":std";は残したままで、アンエスケープ処理の後に utf8::decode($str);でUTF8フラグを落とせば、 スクリプトへのUTF-8文字列の受け渡しも、後続処理も、うまく行きました。 夜更けにお答えくださって、本当にどうもありがとうございました。 これで安心して眠れそうです。
344 名前:デフォルトの名無しさん [2007/04/23(月) 18:08:16 ] ■ Perl言語 ■ 何でも質問コーナー ■ mixi.jp/view_bbs.pl?id=17607679&comm_id=1401396 Perlに関すること、cgiに関すること なんでも質問できるコーナーです(たとえばApacheとかでもOKとします!) (Web系であればOK) ルール: Google検索で調べてわかるようなことでも質問してもOKです (初心者のうちは、どの情報を取捨選択したらイイのかわからないと思うので) 回答してくださるかたは、暖かく質問者を迎えてやってください o(^^o) (o^^)o
345 名前:デフォルトの名無しさん mailto:sage [2007/04/23(月) 18:19:57 ] そのトピック自体はどうでもいいんだが コミュニティのタイトルとか説明文が凄く気になって仕方が無い。
346 名前: ◆TWARamEjuA mailto:sage [2007/04/23(月) 19:56:34 BE:3485748-2BP(6823)] コミュニティの名前 PERL言語 CGI言語 コミュニティの説明 perl言語 cgi言語のコミュニティです だそうです。。。
347 名前:デフォルトの名無しさん mailto:sage [2007/04/24(火) 04:11:19 ] Web系NGなこのスレとうまく連携していければいいですねo(^^)o
348 名前:デフォルトの名無しさん mailto:sage [2007/04/24(火) 08:17:44 ] 未だにCGIが(ry
349 名前:デフォルトの名無しさん mailto:sage [2007/04/24(火) 10:36:14 ] ダメそうなコミュだなw
350 名前:デフォルトの名無しさん mailto:sage [2007/04/24(火) 22:51:58 ] どうしようもない質問の数々に、「ちったぁマニュアル読んでください!」と、 最後に管理者がキレるに1票。
351 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 02:27:30 ] いやあ管理人もろくすっぽ読んでないんじゃないか?
352 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 11:12:27 ] 実は、管理人自身が2ちゃんねるで質問したところ、 「ググれカス」だの「マニュアル嫁」みたいな回答しか 返ってこなかったので、管理人にやさしく教えてくれる ところが欲しかったんじゃないの?
353 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 12:06:40 ] >>352 もちろんそうでしょ。 そうじゃなきゃルール書きの冒頭が「Google検索で調べて わかるようなことでも」で始まるわけないっすよ。
354 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 12:33:51 ] モヒカン族はお断りです><
355 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 17:38:48 ] モヒカン族の土地に侵入してきたくせに、大きい顔をするな
356 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 19:00:43 ] 座り込んで動かない、口だけ達者なでっぷり太ったモヒカン族ほど 役に立たないものはない。 川に流してしまいたい。
357 名前: ◆TWARamEjuA mailto:sage [2007/04/25(水) 20:55:45 BE:980633-2BP(6824)] 不法投棄しちゃダメです♪
358 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 21:32:05 ] 食肉に加工するというのはどうだろう
359 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 22:08:09 ] 強くなれ!! と願いを込めて、子供たちに食べさせるとよいね。
360 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 23:13:46 ] 弱者の肉なんかいくら食べても強くなれないよ
361 名前:デフォルトの名無しさん mailto:sage [2007/04/25(水) 23:27:06 ] 食べるのなら、戦場で最前線に立つモヒカンを食べよう。
362 名前:デフォルトの名無しさん mailto:sage [2007/04/26(木) 09:20:12 ] / : 》:、∩ (===○=)/ センセー __ / ⇔ / 話しについてけませーん \⊂ノ ̄ ̄ ̄\ ||ヽ|| ̄ ̄ ̄ ̄|| ...|| ̄ ̄ ̄ ̄||
363 名前:デフォルトの名無しさん mailto:sage [2007/04/26(木) 22:17:39 ] >>346 CGI言語と来たか・・・。 本当に作ってしまって混乱させるというのはどうか? もちろんその言語はクライアントマシンの限られた 中でしか使えず、 Web の CGI になんて使えないのだ。
364 名前:デフォルトの名無しさん mailto:sage [2007/04/26(木) 22:18:42 ] Common Graphics Interface とかいう紛らわしいグラフィック操作用言語を新たに作る。
365 名前:デフォルトの名無しさん mailto:sage [2007/04/26(木) 23:07:10 ] parrot上で走らせたらもっと混乱の元に。
366 名前:デフォルトの名無しさん mailto:sage [2007/04/26(木) 23:15:11 ] コモン グラフィックス インタープリター 池袋で乗車してきた女の子がハロプロエッグの子とかたかまりこ
367 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 11:39:27 ] ついでだ。IT言語というのも作ってしまえ。
368 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 11:57:03 ] そろそろここは質問箱だということを思いだそう。
369 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 15:28:36 ] そういえば Perl の質問がないなあ・・・。
370 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 15:34:31 ] Chanto Gugure Internet de
371 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 17:29:18 ] perlってグーグル八分されてるんだってね
372 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 18:13:20 ] WindowsでDOSコマンドの結果を取り込むには、 どうすればよろしいでしょうか?例えば、 dir c:\trash の結果を取り込もうとしても、次のスクリプトではうまくいきません。 $files = `dir c:\\trash`; print "The files are $files\n";
373 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 18:43:53 ] GW前に出された宿題で質問が増えるから大丈夫w
374 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 18:53:55 ] >372 手元だとそれでうまくいってるけど。
375 名前:372 mailto:sage [2007/04/27(金) 20:04:12 ] >>374 すみません。書き忘れていました。>>10 にある先頭の5行を入れていました。 use utf8; use open IO => ":encoding(cp932)"; binmode STDIN => ":encoding(cp932)"; binmode STDOUT => ":encoding(cp932)"; binmode STDERR => ":encoding(cp932)"; 「use open IO => ":encoding(cp932)"; 」の行を削除して 次のように修正すると動きました。 use Encode; $orgfiles = `dir c:\\trash`; $files = decode('cp932', $orgfiles); print "The files are $files\n";
376 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 21:23:44 ] >>372 例によって cmd.exe /c dir ... じゃない?
377 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 21:24:53 ] 失礼、関係なかったのね。
378 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 21:35:08 ] >371 記号が多いから、とか?
379 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 22:21:10 ] >>378 うんにゃ、LWPのUAがはじかれる件でしょ?
380 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 22:23:19 ] >>378 Perlで書かれたボットの多くがLWPのデフォルトUser-Agentをそのまま名乗って おり、403を食らうようになった。当然だがUAを変えれば通れる。
381 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 22:24:27 ] Google八分ってのは、Googleの検索結果に出なくなる話だから、 今回のそれとは違うよな。
382 名前:デフォルトの名無しさん mailto:sage [2007/04/27(金) 22:30:29 ] 新しく覚えた言葉を使ってみたかっただけだろ そう責めるな
383 名前:デフォルトの名無しさん mailto:sage [2007/04/28(土) 00:19:39 ] perlのモジュールって一気にアップデートできないの? それとも使う奴だけ手動でアップデートさせるしか方法ない?
384 名前:デフォルトの名無しさん mailto:sage [2007/04/28(土) 00:39:19 ] >383 cpanシェルでupgrade
385 名前:378 mailto:sage [2007/04/28(土) 01:18:47 ] Perlに限らないけど、プログラミング言語の仕様として存在する演算子や記号は検索しづらいよなあ。
386 名前:デフォルトの名無しさん mailto:sage [2007/04/28(土) 03:22:17 ] 不満を抱えるものが改善する。それが基本である。
387 名前:デフォルトの名無しさん mailto:sage [2007/04/28(土) 05:09:49 ] でもそれを誰かが改善したらPythonっぽい何かになるからPythonでいいよねw
388 名前:デフォルトの名無しさん mailto:sage [2007/04/28(土) 17:56:47 ] 比較演算子は記号じゃなくて文字列にすりぁいいんだよな Pealのeqとかみたいにさ
389 名前:デフォルトの名無しさん mailto:sage [2007/04/28(土) 19:26:07 ] >>380 なったと言っても数年前からだよ。 今頃騒いでるやつらはアンテナが低すぎると思ったのだった。
390 名前:デフォルトの名無しさん mailto:sage [2007/04/29(日) 01:57:47 ] struct { char len1; char word1[len1]; char len2; char word2[len1]; char len3; char word3[len1]; } みたいな構造の可変長のバイナリなデータがあるんですが、 これをperlで綺麗でかっこよく展開する方法ってないですか? 今は下のようなことをしてるのですが、なんか見辛いし汚いので… $data = "\4ABCD\3EFG\7HIJKLMN"; ($len1,$data) = unpack("Ca*",$data); ($word1,$data) = unpack("a${len1}a*",$data); ($len2,$data) = unpack("Ca*",$data); ($word2,$data) = unpack("a${len2}a*",$data); ($len3,$data) = unpack("Ca*",$data); ($word3,$data) = unpack("a${len3}a*",$data); print "$word1\n$word2\n$word3\n";
391 名前:デフォルトの名無しさん mailto:sage [2007/04/29(日) 03:40:49 ] 少なくともループ構造にするべきだと思う
392 名前:デフォルトの名無しさん mailto:sage [2007/04/29(日) 04:06:37 ] >>390 perldoc -f pack して目を皿のようにして熟読せい。 The "/" template character allows packing and unpacking of strings where the packed structure contains a byte count followed by the string itself. You write *length-item*"/"*string-item*.
393 名前:デフォルトの名無しさん mailto:sage [2007/04/29(日) 05:12:56 ] >>392 あああああ、そんなテンプレートがあったんですね。 日本語の5.6ベースのman見てたので気づきませんでした… ありがとうございます。
394 名前:デフォルトの名無しさん mailto:sage [2007/04/30(月) 02:59:39 ] >>393 あ、すまん。 5.6からの拡張だと思ってたが、違ったか(393には問題ないみたいでよかった)。
395 名前:デフォルトの名無しさん [2007/05/01(火) 17:38:05 ] ファイル内の文字列を置換するスクリプトを書いているところなのですが、 「置換する」「置換しない」(飛ばす)「残り全て置換」「キャンセル」という 処理を行うにあたって、見つけた文字列を置換せずに飛ばして次を置換する 方法が思いつきません。置換しないテキストは適当な文字列に置換しておいて 最後に戻すという方法も考えたのですが、あまりスマートではないと思いまし た。何かよい方法があったら、お知恵をお貸しください。 while($text =~ /($regexp)/) { if($all == 0) { $before = $1; $after = $1; $after =~ s/$regexp/$replace/m; print "置換前:\n$before\n置換後:\n$after\n"; do { print "置換する? [y]es [n]o [a]残り全て [g]キャンセル "; $key = <STDIN>; chomp($key); } while ($key ne "y" and $key ne "n" and $key ne "a" and $key ne "g"); if($key eq "y"){ $text =~ s/$regexp/$replace/m; }elsif($key eq "n"){ # ここをどうする? }elsif($key eq "a"){ $text =~ s/$regexp/$replace/gm; $all = 1; }else{ exit; } }elsif($all == 1) { $text =~ s/$regexp/$replace/gm; } }
396 名前:395 [2007/05/01(火) 17:39:43 ] 補足です。$textはファイルの内容、$regexpは置換前の文字列、$replaceは 置換後の文字列です。
397 名前:デフォルトの名無しさん mailto:sage [2007/05/01(火) 17:51:02 ] >>395 ヒント: posと\G perl -e '$x = "aaaaaa"; pos($x) = 2; $x =~ s/\Ga/x/; print $x,"\n";' aaxaaa
398 名前:395 [2007/05/01(火) 21:09:08 ] ありがとうございます、無事できました。コードはこのようになりました。(たぶん問題ないはず…) $p = 0; while($text =~ /\G(?:.*\n)*?.*?($regexp)/gm) { $p = pos($text) - length($1); pos($text) = $p; if($all == 0) { $before = $1; $after = $1; $after =~ s/$regexp/$replace/m; print "置換前:\n$before\n置換後:\n$after\n"; do { print "置換する? [y]es [n]o [a]残り全て [g]キャンセル "; $key = <STDIN>; chomp($key); } while ($key ne "y" and $key ne "n" and $key ne "a" and $key ne "g"); if($key eq "y"){ $text =~ s/\G$regexp/$replace/m; pos($text) = $p + length($after); }elsif($key eq "n"){ pos($text) = $p + length($before); }elsif($key eq "a"){ $text =~ s/\G$regexp/$replace/gm; $all = 1; }else{ exit; } }elsif($all == 1) { $text =~ s/\G$regexp/$replace/gm; } }
399 名前:デフォルトの名無しさん mailto:sage [2007/05/01(火) 21:31:38 ] \Gの使い方がおかしいような 最後の全置換は絶対うまくいかんだろ
400 名前:デフォルトの名無しさん mailto:sage [2007/05/01(火) 22:01:18 ] せっかく書いたんだからたぶんとかいってないで動かしてみるべきだな。
401 名前:395 mailto:sage [2007/05/01(火) 22:02:38 ] すみません、やっぱ問題がありました。置換位置\Gが正規表現に含まれている と、置換される文字列に改行が含まれている際に、オプション"g"をつけても 複数置換してくれなくなってしまうのですが、どうすればいいんでしょうか。 perl -e '$text = "a\na\na"; $text =~ s/\Ga/b/gm; print "$text\n";' 結果: b a a perl -e '$text = "aaa"; $text =~ s/\Ga/b/gm; print "$text\n";' 結果: bbb perl -e '$text = "a\na\na"; $text =~ s/a/b/gm; print "$text\n";' 結果: b b b
402 名前:デフォルトの名無しさん mailto:sage [2007/05/01(火) 22:23:56 ] \Gは置換文では使わないほうがいいよ。代入されるとposがリセットされてしまうから あとを置換しながらposを保持することはできないのでコピーを作ることを考えてみては 自分ならこう書く my $replaced_text; pos $text = 0; while (pos $text < length $text) { if ($text =~ m/\G $regexp/gcsx) { # ここで入力による分岐処理を行う } elsif ($text =~ m/\G(.+?) (?=$regexp)/gcsx) { $replaced_text .= $1; } else { $text =~ m/\G (.*)/gcsx; $replaced_text .= $1; }
403 名前:デフォルトの名無しさん mailto:sage [2007/05/01(火) 22:28:17 ] s///gが一種のループなのでこんな手もある。 my $mode; $text =~ s{($regexp)}{ my $r; if (!defined $mode) { my $key; do { print "置換する? [y]es [n]o [a]残り全て [g]キャンセル "; $key = <STDIN>; chomp($key); } while ( $key ne "y" and $key ne "n" and $key ne "a" and $key ne "g" ); if ($key eq 'y') { $r = $replace; } elsif ($key eq 'n') { $r = $1; } elsif ($key eq 'a') { $mode = 'a'; } else { $mode = 'g'; } } if ($mode eq 'a') { $r = $replace; } elsif ($mode eq 'g') { $r = $1; } $r; }gme;
404 名前:395 [2007/05/01(火) 23:34:11 ] >>402-403 おお、これはすごい、正規表現でループができるんですね。 >>403 の方法できれいなスクリプトになりました。ありがとうございます。
405 名前:デフォルトの名無しさん mailto:sage [2007/05/02(水) 03:13:40 ] CPANシェルについてなんですが、 インストールするごとに[1]とか[2]とか増えるのはなんなんでしょうか?
406 名前:デフォルトの名無しさん mailto:sage [2007/05/02(水) 03:44:02 ] >>405 現在実行したコマンドを識別するIDみたいなもの。 何に使ってるかまでは見てないけど。 ちなみに↓とやるとIDを変えてしまうこともできる。特に意味はない。 cpan[1]> ! $CPAN::CurrentCommandId = 100;
407 名前:デフォルトの名無しさん mailto:sage [2007/05/02(水) 05:56:50 ] >>406 レスありがとうございます。 そうなんですか。 なんか Bundle::CPAN をインストールしてからそうなったような気がしたので、 間違えたかと思いました。 そのような情報ってどこで得ているのでしょうか?
408 名前:デフォルトの名無しさん mailto:sage [2007/05/02(水) 09:35:32 ] モジュール(lib/CPAN.pm)のコードを読む。
409 名前:デフォルトの名無しさん mailto:sage [2007/05/02(水) 14:03:43 ] >>406 知らないけど、ヒストリ用では? よくUNIX用のシェルであるんだけど、 ! の直後にその番号入れて 実行するとその番号のコマンドが動くんだよ。全く同じなら再入力 する必要がないの。(更に後ろに :s/// のようなのを付けて文字列 置換できたりもする。 !30:s/aa/bb/ みたいな。全てのシェルが 同じこと出来るかどうかは知らないが)。
410 名前:デフォルトの名無しさん mailto:sage [2007/05/02(水) 21:18:49 ] cpanpのメリットがイマイチわからん
411 名前:デフォルトの名無しさん mailto:sage [2007/05/02(水) 21:20:37 ] 最近CPAN.pmがだいぶ進化したからCPANPLUS.pmの意義が相対的に薄くなったしねー
412 名前:デフォルトの名無しさん mailto:sage [2007/05/03(木) 06:35:39 ] awkは多少かじったのですが、perlはまるっきりの初心者です。どなたかお知恵を貸して下さい。 2つのファイル a.txt と b.txt を比較して、条件にあった行を抽出、出力するスクリプトを作りたいのです。 具体的には、 [a.txt] ID, field1, field2 1, 5.8, 7.3 2, 6.3, 8.2 3, 3.2, 4.1 4, 4.8, 4.0 5, 8.3, 10.2 [b.txt] ID, field1, field2 1, 6.8, 7.7 3, 4.3, 5.5 4, 5.9, 4.9 というファイルがあったとき、b.txt のIDに数値が存在する行だけを a.txt から抽出して a2.txt として保存したいのです。 [a2.txt] ID, field1, field2 1, 5.8, 7.3 3, 3.2, 4.1 4, 4.8, 4.0 と言った具合にです。よろしくお願いします。
413 名前:デフォルトの名無しさん mailto:sage [2007/05/03(木) 07:47:00 ] #!/usr/bin/perl use strict; use warnings; open my $a, '<', 'a.txt' or die; open my $b, '<', 'b.txt' or die; my %ids = map { $_ => 1 } map { (split /,/)[0] } <$b>; while (<$a>) { my $id = (split /,/)[0]; print if $ids{$id}; }
414 名前:412 mailto:sage [2007/05/03(木) 08:00:05 ] >>413 さま 早速のレス、ありがとうございます。助かりました。 こんなに簡単にできちゃうんですね。しかし、私にはスクリプトの内容は不明...。解読して勉強させていただきます。
415 名前:デフォルトの名無しさん mailto:sage [2007/05/03(木) 13:36:22 ] use IO::File; sub func { my $file = shift(@_); my $input = IO::File->new($file,"r") or die; ごにょごにょ ・ ・ } $filename = (ディレクトリからファイルネームをとるロジック); &func($filename); みたいに書くと、一番最初にいきなりファイルオープンのエラーが出ます。 その後、ファイルネームをとるロジックが走ってる模様…。 何故か解らないのですが原因解りますでしょうか。
416 名前:デフォルトの名無しさん mailto:sage [2007/05/03(木) 13:48:01 ] >>415 原因はわかりますよ。 あんたが、そう動くようにプログラムを作ったから。
417 名前:415 mailto:sage [2007/05/03(木) 13:53:53 ] >>416 早い回答ありがとうございます。 やっぱり自分が悪いんですね。 調べてみます。
418 名前:415 mailto:sage [2007/05/03(木) 14:26:25 ] うーんやっぱり解らない…。 サブルーチンが先に実行される事なんてあるのか…?
419 名前:デフォルトの名無しさん mailto:sage [2007/05/03(木) 14:50:10 ] >>415 まあエラーメッセージでも貼ってみ
420 名前:415 mailto:sage [2007/05/03(木) 15:05:12 ] >>419 そのようなファイルやディレクトリはありません at (何行目) としか出ないんですが…。
421 名前:デフォルトの名無しさん mailto:sage [2007/05/03(木) 15:08:03 ] >>420 訳したりせずにそのまま貼れ
422 名前:415 mailto:sage [2007/05/03(木) 15:16:54 ] そのようなファイルやディレクトリはありません at test.pl line 32. だけです。 CentOS4.4、perl5.8.5です。
423 名前:415 mailto:sage [2007/05/03(木) 15:30:01 ] フルパス指定してなかった…。 >>422 さん、親身になってくれてありがとうございます。 くだらないミスで申し訳ありません。 本当にすみませんでした。
424 名前:デフォルトの名無しさん mailto:sage [2007/05/03(木) 15:40:40 ] >>423 s/422/421/g;
425 名前:デフォルトの名無しさん mailto:sage [2007/05/03(木) 15:47:38 ] 突っ込みどころはいろいろあるけど、エラーメッセージは自分のためにも他人のためにもわかりやすくすべし。 my $fp_in = IO::File->new($filename, "<") or die qq(cannot open '$filename': $!);
426 名前:415 mailto:sage [2007/05/03(木) 16:07:57 ] >>425 了解です。ただ or die $!;だけしてました。 連休中にコメントありがとうございました。
427 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 14:17:50 ] chompって何の略ですか?
428 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 14:26:54 ] >>427 略じゃないよ。 噛み切るとかそんな感じ。
429 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 14:41:24 ] chomp 【自動】 〜をムシャムシャ食う◆【同】champ
430 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 14:43:41 ] へー。ありがとうございました。
431 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 15:30:31 ] オブジェクト指向で書いていないので、巨大モジュールの分割がうまいこといかんのです>< 具体的には、親パッケージが子パッケージをuseしているとき、 子パッケージから親パッケージのサブルーチンを呼べません。 Giko.pm [------- package Giko; use Giko::Mona; (omaemonaサブルーチンをEXPORTしている) sub omaemona { .... } -------] Giko/Mona.pm [------- package Giko::Mona; -------] となっていた場合、 Giko::Monaの中でomaemonaを呼ぶ方法は、Giko::omaemonaしかないでしょうか? Giko::Monaでuse Gikoはできないし、use base 'Giko';は違うみたいですし。
432 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 17:12:46 ] Encodeモジュールのfrom_toを用いて 「@」「A」や「T」「U」などを sjis <-> euc-jp 変換すると文字化けしてしまいます。 回避するにはどうすればいいでしょうか?
433 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 19:33:33 ] >>432 つEncode::EUCJPMSのcp51932
434 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 20:32:56 ] それは拡張文字なので、 sjis じゃなく cp932 を指定。
435 名前:デフォルトの名無しさん mailto:sage [2007/05/05(土) 20:40:22 ] 単純に分割するなら、全部同じ名前空間に展開すればいいんじゃない Giko/Mona.pm [------- package Giko::Mona; package Giko; -------]
436 名前:431 mailto:sage [2007/05/06(日) 01:14:39 ] 遅レスで申し訳ないです。 >>435 なるほど。 まとめると巨大ファイルになりがちで不安だったのですが、 今のところはまだなんとか1ファイルにまとめられそうなので、 同じファイルスコープで仲良く共存してみます。 ありがとうございました。
437 名前:デフォルトの名無しさん mailto:sage [2007/05/06(日) 17:12:14 ] 例 ( split /\//, $x )[0 .. bar]; リストの末尾要素を除いたリストを返す方法、知りませんか? barをどう記述すりゃいいのやら。 Perl ならできそうな気がするんですが。思い当たりません。 検索してみたものの、それらしいものも見つけられません。
438 名前:デフォルトの名無しさん mailto:sage [2007/05/06(日) 17:31:22 ] ( @hoge, undef ) = split //, $foo ; じゃダメなの?
439 名前:デフォルトの名無しさん mailto:sage [2007/05/06(日) 17:43:01 ] >>437 尻尾だけ消すのじゃだめなの?