1 名前:デフォルトの名無しさん mailto:sage [2010/02/19(金) 16:47:06 ] "The duct tape of the Internet" こと、Perl についての質問箱です。 "There's more than one way to do it" ということで、 Perl の奥深さについて皆で語り合い、追求してまいりましょう。 CGI についての質問は板違いです。WEB プログラミング板でどうぞ。 CGI と Perlの区別がつかない人も WEB プログラミング板に行ってください。 (WEB プログラミング板: pc11.2ch.net/php/ ) CGI の質問は答えが Perl と全然関係ない話に帰着する場合が 多かったりするので WEB プログラミング板に行って聞いたほうが得ですよ。 このスレでは(CGI 以外の)純粋にPerlのみに関係する質問を取り扱っていこうと思います。 スレ違いの質問にはスルーか、速やかな誘導をお願いします。 www.perl.org/get.html ● 2010/02/19 現在の最新版: 5.10.1 ▼ 前スレ Perlについての質問箱 42箱目 pc12.2ch.net/test/read.cgi/tech/1257139591/ リンク集は >>2-3 Perl 日本語処理の基礎の基礎 >>4 過去スレは >>5-7 あたり
348 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 03:44:17 ] >>347 安心した やり方を教えてちょ
349 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 04:42:20 ] 何だよ「特定の行」って
350 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 06:11:15 ] 質問の意図するところが分からない。このうちのどれか? use strict; use warnings; print "is\nthis\nunko?\n"; use strict; use warnings; print << "END_OF_UNKO"; this is unko! END_OF_UNKO use strict; use warnings; use HTML::Template; my $what_is_this = join "", <DATA>; my $t = HTML::Template->new( scalarref => \$what_is_this ); $t->param('var', "was"); print $t->output; __DATA__ this <TMPL_VAR name="var"> unko!
351 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 06:50:15 ] >>348 use IO::File; my $fh = IO::File->new('hoge.txt', 'r'); while(my $line = $fh->getline){ print $line; print "\n" if $line =~ /hoge/; } こんな漢字?
352 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 09:22:29 ] $. == 行番号 とか。
353 名前:デフォルトの名無しさん [2010/05/15(土) 11:21:19 ] perlで作った掲示板の連続投稿を制限する方法を教えてください。 一定時間が経過するまで再投稿できないようにしたいです。
354 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 11:59:34 ] 投稿者のIDに対して最後の投稿時間を記録する
355 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 12:24:13 ] 小規模ならグローバルでもいいんじゃないの? # 30秒経過してない場合returnする return if $g_last_post + 30 > time; $g_last_post = time;
356 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 14:35:57 ] >>353 IPのログはとってんだろ? そこから判定すりゃいい samba24みたいな手にするって方法もあるな ちょっと技術がいるかも知れないが
357 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 14:55:21 ] 普通はそんなめんどいことしないでクッキー食わせて判定だと思うぜ
358 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 15:04:37 ] ログは巨大だからなあ 自前でテーブル持つ方が軽い
359 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 15:21:54 ] いやだから普通はクッキーだろっての
360 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 15:55:01 ] ↑バカは喋るな
361 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 15:58:24 ] >>359 クライアントが書き込み後にクッキー捨てたらアウトだと思うんだがそうでもないのか もうちょっと詳しく
362 名前:デフォルトの名無しさん [2010/05/15(土) 16:01:51 ] >>349-352 長いテキストがあり、100文字目ごとに改行を入れるということです。 分かりにくくて申し訳ありませんでした。
363 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 16:17:33 ] 2chもクッキーだな
364 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 16:27:54 ] >>362 Text::LineFold >>353 ,354-359,361,363 板違い pc11.2ch.net/php/
365 名前:デフォルトの名無しさん mailto:sage [2010/05/15(土) 16:29:03 ] 一足遅かったか >>362 >>3 www.din.or.jp/~ohzaki/perl.htm#JP_Fold search.cpan.org/search?m=all&q=fold&n=100 >>353 △▲ WebProg 初心者の質問 Part22 ▼▽ pc11.2ch.net/test/read.cgi/php/1272872528/
366 名前:デフォルトの名無しさん [2010/05/16(日) 21:25:10 ] funcA(); if(hoge){ funcAErr(); } else { funcB(); if(fuga){ funcBErr(); } else { funcC(); if(fuga){ resultA(); } else{ resultB(); } } } こんな感じで事前処理にこけたら弾き、を繰り返して最後の処理で結果Aか結果Bのいずれかを返す、 と言ったコードがあるんですが、これをもっとPerlらしくシンプルに書きたいんだがどう書けばいいだろう……。 (ifネストが実際には3階層ではなく20階層くらいあります)
367 名前:デフォルトの名無しさん mailto:sage [2010/05/16(日) 21:43:55 ] >>366 funcA() や funcB() の戻り値は無いのかとか、hoge や fuga が何を判定してるのかとか、 funcAErr() でなく funcErr('A') じゃダメなのかとか、エラー処理後に戻ってくる (if then else で括る) 必要があるのかとか、Perlらしさ以前の問題だと思う。
368 名前:デフォルトの名無しさん mailto:sage [2010/05/16(日) 21:45:08 ] こんな感じの改造すれば良いんちゃう? my @tasks = ( sub { () }, # <= funcA() とかが入る。 sub { () }, sub { () }, sub { () }, sub { () }, sub { () }, sub { 42 } ); my $argument ; for ( @tasks ){ my $flag = $_->( $argument ) ; next if ! $flag ; # エラー処理やりたきゃ、ここを真面に。 print qq{${flag}hoge\n} ; last ; }
369 名前:デフォルトの名無しさん mailto:sage [2010/05/16(日) 22:25:07 ] >>366 エラー処理はfuncA()、funcB()の中で例外発生させて 全体をevalブロックでくくり、例外をキャッチして処理 エラー以外の分岐は適当に処理をブロックでくくり、last、redoなどでコントロール eval { funcA(); funcB(); { funcC(); if (fuga) { resultA(); last } resultB(); } }; if ($err = $@) { $err->A ? funcAErr() : $err->B ? funcBErr() : $err->C ? funcCErr() : Err(); }
370 名前:デフォルトの名無しさん mailto:sage [2010/05/16(日) 22:49:10 ] メールを受信して、添付の画像ファイルを画像処理し、サーバに保存したいと考えています。 メール受信時に本プログラムにメールを渡すようにメールサーバは設定しています。 以下ソースの関係している部分です。 ----mailimage.pl----- my $parser = MIME::Parser->new; #ファイルの一時保存場所を指定 $parser->output_dir('./tmp'); $filename=''; #標準入力からメールを取得 my $entity = $parser->parse(*STDIN); #添付ファイルがある場合のみ処理 if($entity->is_multipart){ #パートの数(本文と添付ファイルの合計数) $count = $entity->parts; #メール本文以外(添付のみ)を取り出し(本文は0番目のため、一番目から取り出し) for($i = 1; $i < $count; $i++){ #ファイル名を含むパスを取り出し $path = $entity->parts($i)->bodyhandle->path; #ファイル名を取り出し $filename =time. (fileparse($path))[0]; $filenameglobal=$filename; `./out1 $path outputimg/$filename.bmp`; } } out1というプログラムが画像処理を行うファイルで、第一引数に入力を、第2引数に出力先をとるように作成しています。 mailimage.pl < sample.eml といった具合に、ローカル環境でeメールファイルを渡してやった場合は正常に動作します。 しかし、実際にメールを受信するとtmpファイルへの保存は行われるのですがout1で得られるべき出力画像が得られません。 どうやら、tmpフォルダに保存される前にout1を呼び出しているようで、入力がない状態になってしまっているようです。 解決策のご提示をよろしくお願いいたします。 また、一度ファイルに保存することなく直接メモリ上で受け渡す方法などもご提示いただけると幸いです。
371 名前:デフォルトの名無しさん [2010/05/17(月) 01:35:34 ] perl から任意のアプリ(例えばメモ帳)を起動したいんだけどどう書けば良いのでしょうか?
372 名前:デフォルトの名無しさん mailto:sage [2010/05/17(月) 01:49:44 ] perl -e "`notepad`
373 名前:デフォルトの名無しさん [2010/05/17(月) 22:55:18 ] cpan> install XML::Atom *********いろいろ展開されて Please download the file manually, save it to a directory in %PATH% (e.g. C:\WINDOWS\COMMAND\), then launch the MS-DOS command line shell, "cd" to that directory, and run "Nmake15.exe" from there; that will create the 'nmake.exe' file needed by this module. You may then resume the installation process described in README. ------------------------------------------------------------------------------- Warning: No success on command[C:\Perl\bin\perl.exe Makefile.PL INSTALLDIRS=site] MIYAGAWA/XML-Atom-0.37.tar.gz C:\Perl\bin\perl.exe Makefile.PL INSTALLDIRS=site -- NOT OK Running make test Make had some problems, won't test Running make install Make had some problems, won't install Failed during this command: MIYAGAWA/XML-Atom-0.37.tar.gz : writemakefile NO 'C:\Perl\bin\perl.exe Makefile.PL INSTALLDIRS=site' ret urned status 512 cpan> と表示されてしまいました。とりあえず、nmake.exe はダウンロードしました。 これからどうすればいいでしょうか?
374 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 00:12:07 ] >>373 今使ってるperlをアンインストールしてActivePerlの最新版をインストールし、PPMを使え
375 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 00:23:08 ] うちcpanが成功した試しがないわ ppmならokだけど
376 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 05:28:00 ] XS系はことごとく失敗する気がする… 特にXMLやHTMLのパーサー関連は入らん at Ubuntu
377 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 06:13:44 ] まさかbuild-essential入れてないとかじゃないよな
378 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 06:45:12 ] XML-Atomはppmに無いからめんどくさいんだよな だから俺は使ってない あとこいつマルチだな
379 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 08:46:53 ] 今ならStrawberry Perl入れた方が楽じゃない? XML::Atomもすんなり入ったよ
380 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 08:55:06 ] そもそもwindows系OSでperl使うのがすでに茨の道とも言える
381 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 10:03:01 ] なんで?
382 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 11:48:53 ] >>378 リポジトリにこれ加えとけ。 trouchelle.com/ppm10/package.xml
383 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 12:20:10 ] elseifでなく何故elsifなんですか?
384 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 13:26:56 ] 母音が続くのが気持ち悪いから elifじゃないのと聞かれたら解答に窮するが、CPPはelifなんだよな 文化によって多少違いはあるが、やはり、母音が続くのが気持ち悪いんだと思う
385 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 13:55:38 ] いっそのことelfでいいじゃん。 短いし。
386 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 15:33:01 ] 最近プログラミングの勉強を始めました print "hello world"; と書いてhello.plで保存し、ターミナルで perl hello.pl と入力するのはわかったんですが、hello.plはどこに保存すればいいのですか? 環境はMac OS Xです
387 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 16:10:27 ] >>386 好きな場所
388 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 16:28:15 ] >>386 今自分がいる場所におけばいい 違う場所に置きたいならフルパスで指定すれば実行できる
389 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 16:41:23 ] >>382 サンクス つか、ppmguiにリポジトリのサジェストなんてあったんだな そこにも載ってたわ 重ねてサンクス
390 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 17:56:24 ] >>386 perlの前にターミナルの使い方を覚えるためのBash入門を読んだ方が良いかも。
391 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 18:42:40 ] それは的外れなアドバイス
392 名前:373 mailto:sage [2010/05/18(火) 21:37:27 ] ATOM::XML をWinXP/Active Perl に入れたい なにかヒントありますか? >>374 >>375 >>379 ストロベリー入れましたけど、Activeパールと同じエラーです。 (nmake をダウンロードして、ダウンしたパッケージをmake して、 それから、再度ACTIVE Perl で,ATOM::XMLしたときとです。 やはり、パッケージが問題なのかな? cpan> install ATOM::XML Fetching with LWP: cpan.strawberryperl.com/authors/01ma Fetching with LWP: cpan.strawberryperl.com/modules/02pa Fetching with LWP: cpan.strawberryperl.com/modules/03mo Creating database file ... Gathering information from index files ... Populating database tables ... Done! Warning: Cannot install ATOM::XML, don't kn Try the command i /ATOM::XML/ to find objects with matching identifiers.
393 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 21:44:02 ] 現在 WinXP上にActivePerlが入っています。StrawberrryPerlを入れて共存できるのでしょうか?
394 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 21:49:59 ] エラーメッセージくらい読めよ
395 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 21:52:02 ] 普通に考えるとパッケージ名ってAtom::XMLもしくはXML::Atomだからでは
396 名前:373 mailto:sage [2010/05/18(火) 21:57:06 ] とりあえず、 install XML::Atom::Feed とすると、したみたいになった。これってATOM::XML ってインストールできたのかな Prepending C:\strawberry\cpan\build\XML-Atom-0.37-H4btN8/blib/arch C:\strawberry \cpan\build\XML-Atom-0.37-H4btN8/blib/lib to PERL5LIB for 'install' Installing C:\strawberry\perl\site\lib\XML\Atom.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Base.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Category.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Client.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Content.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Entry.pm Installing C:\strawberry\perl\site\lib\XML\Atom\ErrorHandler.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Feed.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Link.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Person.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Server.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Thing.pm Installing C:\strawberry\perl\site\lib\XML\Atom\Util.pm Appending installation info to C:\strawberry\perl\lib/perllocal.pod MIYAGAWA/XML-Atom-0.37.tar.gz C:\strawberry\c\bin\dmake.EXE install UNINST=1 -- OK cpan>
397 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 22:13:16 ] perlで添付ファイル取得して、それをopencvに渡して結果を保存したいんだが、出来ない。 ローカルでemlファイル読み込ませるといけるのに、メール受信をトリガに起動するとだめだ・・。 どうして?
398 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 22:32:58 ] >>396 OKってかいてありますやん 心配なら $ perldoc XML::Atom
399 名前:デフォルトの名無しさん mailto:sage [2010/05/18(火) 22:34:23 ] >>396 XML::Atom と ATOM::XML は全く別のモジュールだ。 (存在すればの話しだが) お前さんが、いくら XML::Atom を入れたとしても、 ATOM::XML は永久に入らん。 気持悪いったらありゃしない。
400 名前:デフォルトの名無しさん mailto:sage [2010/05/19(水) 12:22:56 ] アハハハ
401 名前:デフォルトの名無しさん [2010/05/19(水) 14:46:33 ] たとえば、[[:ascii:]]から'<'を除いた文字クラスを表わすにはどうしたらいいでしょうか?
402 名前:デフォルトの名無しさん mailto:sage [2010/05/19(水) 18:51:09 ] もともと入ってないやん
403 名前:デフォルトの名無しさん mailto:sage [2010/05/21(金) 21:53:00 ] 数百のファイルを処理するPerlスクリプトがありまして、それがシーケンシャルに処理してて クソ時間がかかるため、マルチスレッドでやらせようとPerlについて勉強しています。 で、いまんとこ、セマフォで並列処理数を制御し、joinするためだけのスレッドを動かして かたっぱしからjoinするようにしています。おかげで処理時間は半分以下になったのですが、 これを添削していただけないでしょうか。もっとエレガントなやり方があれば教えていただきたいです。 よろしくおねがいします。 #!/usr/bin/perl use strict; use File::Basename; use File::Path; use threads; use threads::shared; use Thread::Semaphore; use Codemap; use SVG; my $concurrency = 5; my $semaphore = Thread::Semaphore->new($concurrency); my $exitflag :shared = 0; my $jointhreads = threads->new(\&joinThreads); while (@ARGV) { my $orig_svg = shift(@ARGV); $semaphore->down; threads->new(\&doSplit, $semaphore, $orig_svg); } $exitflag = 1; $jointhreads->join; exit 0;
404 名前:403のつづき mailto:sage [2010/05/21(金) 21:53:56 ] sub joinThreads { until ($exitflag) { foreach my $thr (threads->list) { if ($thr->tid and !threads::equal($thr, threads->self)) { $thr->join; } } print "\nThreads joined.\n"; } } sub doSplit { my $semaphore = shift; my $orig_svg = shift; my $svg = new SVG($orig_svg); $svg->setdumpdir("work.d"); if ($svg->modtime() > $svg->splittime()) { $svg->dump(); print STDERR " $svg->{filename} : splitted\n" } else { print STDERR " $svg->{filename} : SKIP\n" } $semaphore->up; }
405 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 14:07:11 ] UTF8の〜をshift_jis(cp932)に変換して出力するとエラーが出てしまいます。 解決策があれば教えていただきたいです。 環境はWindows 7 64bitとActivePerl v5.10.1 64bitです。 use utf8; binmode STDOUT, ":encoding(cp932)"; print "昨日は10時〜6時まで寝た。\n"; D:\>test.pl "\x{301c}" does not map to cp932 at D:\test.pl line 3. 昨日は10時\x{301c}6時まで寝た。
406 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 14:20:39 ] D:\>test.pl 何故こんなところで作業しているのか
407 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 14:54:09 ] 「〜」には FULLWIDTH TILDE (FF5E) WAVE DASH (301C) の二種類がある。
408 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 14:57:40 ] 〜の厄介さはMacを使ってるとよく分かる
409 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 16:10:32 ] macでなくても〜は厄介
410 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 16:13:53 ] Macだとプログラムとか使わなくても 普段から〜が厄介になる
411 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 16:15:49 ] え? 俺は生粋のマカーだけど、厄介さが全然分からん。 何かトラブるっけ? "〜"って。 Mac<=>Winのデータ交換とかの話し?
412 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 16:21:41 ] Macで〜と書き込んだら Winだと逆向きの波線に見えたり 最近は大丈夫な気はするが
413 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 16:31:53 ] 〜が厄介なんて、OS9時代の話だろ。 昔から機種依存文字問題とか、今はUTF8-macとUTF-8とか もっと厄介なモンがあるから。
414 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 16:54:16 ] OSXでの話だが
415 名前:405 mailto:sage [2010/05/22(土) 17:06:03 ] 皆さんレスありがとうございます。 >>405 はmeadowから打ち込んだ〜は\x{301c}となり、 notepad等から打ち込んだ〜は\x{ff5e}になる事が原因で表示に失敗していました。 \x{301c}はshift_jisでは表示に成功しcp932では失敗しました。 \x{ff5e}はcp932では表示に成功しshift_jisでは失敗しました。 どうやらeucとsjisの〜はutf8の\x{301c}に対応していて cp932の〜はutf8の\x{ff5e}に対応しているようでした。 なので例えばeucの〜をutf8に変換し、それをcp932に変換すると失敗するようです。 挙動がおかしいと思った元のプログラムではネット上にあるeucのページを取ってきて utf8に変換し出力時にcp932に変換していたので上記の理由で文字化けしていた様です。 そこでeucをutf8に変換した際に\x{301c}を\x{ff5e}に変換するようにしました。 $utf8data =~ tr/\x{301c}/\x{ff5e}/; そうしたところprintした際に"\x{301c}" does not map to cp932というエラーも出ず、無事〜が表示されるようになりました。
416 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 17:10:30 ] 意味不明
417 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 19:23:59 ] >>405 use utf8は「フツーは使うな」とCPANに書いてあった気がする。 Windowsを呪いながらEncode使え。 #!perl use Encode; my $msg = "昨日は10時〜6時まで寝た。\n"; Encode::from_to($msg, 'utf8', 'cp932'); print $msg;
418 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 19:39:43 ] >use utf8は「フツーは使うな」 理由は?
419 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 20:34:20 ] >>417 >use utf8は「フツーは使うな」とCPANに書いてあった気がする。 どこに書いてあったの?聞いたことない
420 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 21:01:51 ] > Do not use this pragma for anything else than telling Perl that your script is written in UTF-8. もしかしてこれの事か?
421 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 21:08:00 ] >>417 そのEncodeの作者が >スクリプトはUTF-8で書き、use utf8;するのがモダンPerlのあり方です。 って言ってるけどな。 ttp://blog.livedoor.jp/dankogai/archives/51221731.html
422 名前:デフォルトの名無しさん [2010/05/22(土) 22:19:22 ] 文字列の切り取りに関して質問があります。 $a="aho"; $b="baka"; $str="ahomanukebaka"; $strには$aと$bで"manuke"という文字が挟まれています。 このとき$strからmanukeだけを切り抜くにはどうすればよいでしょうか?
423 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 22:24:54 ] substr($str, length($a), length($str)-length($a.$b));
424 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 22:48:06 ] >>422 my $a1 = "aho"; my $b1 = "baka"; my $str = "ahomanukebaka"; $str =~ s/$a1(.*)$b1/$a1$b1/; warn $str; # ahobaka warn $1; # manuke
425 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 23:01:54 ] 失敗してるのに前の$1を読んでしまう
426 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 23:16:31 ] >>425 あぁ、ごめん。本当はifとかやるけどmanukeが必要なのかどうなのかわからなくて とりあえず$1に入ってるよって言いたかった
427 名前:デフォルトの名無しさん mailto:sage [2010/05/22(土) 23:22:02 ] >>424 できましたありがとうございます!
428 名前:417 mailto:sage [2010/05/23(日) 01:13:47 ] >>420 それだ。 WWW::Mechanizeでcp932受け付けんからEncode::decode_utf8($massage)とかやってたのに、 use utf8だけで済んだのか・・・・クソアホみたいだわorz
429 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 13:00:16 ] 正規表現のグルーピングについて質問です 繰り返し表れる対象をグループ化したいのですが良いやり方ありますか? gオプション付けたら行けるかと思ったらダメだった。 my $str = << 'END'; aba aca ada END $str =~ m{(a[^a]a)\n\n}g; # これだと初めの対象にしかマッチしない
430 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 13:23:18 ] >>429 g(global?)オプションだけでなく m(multi line?)オプションもいるんじゃなかったっけ
431 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 13:27:20 ] >>429 こう? my @matches = $str =~ m{(a[^a]a)\n\n}g;
432 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 13:32:54 ] >>430 $str =~ m{(a[^a]a)\n\n}mg; これも試したけどダメだったんだよね >>431 おぉ。いけました。 ちなみに=と=~を一緒に書くとわかりにくいので別にする方法ってありますか? 普通のマッチの場合、下みたいに分けたりしてるのだけどそういう方法があれば教えてください warn $1 if $str =~ m{(a[^a]a)\n\n}g;
433 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 13:41:44 ] >>432 ifをwhileに変えるだけ warn $1 while $str =~ m{(a[^a]a)\n\n}g;
434 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 13:59:57 ] gオプションが付いても付かなくても 正規表現に括弧がひとつしかないから、$2と$3は未定義。 ループを回すたびに$1の内容が変わる。
435 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 14:09:01 ] my @matches; push @matches, $1 while $str =~ m{(a[^a]a)\n\n}g;
436 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 14:25:05 ] while m//g とか while each %hash って気持ち悪いな
437 名前:429 mailto:sage [2010/05/23(日) 14:34:43 ] >>433-435 なるほど!ありがとうございます。while使うのかぁ。知らなかった。 perldoc perlreに書いてあるのかなぁって探してみたら書いてあった。勉強になりました。 @matches = ( 'foo' =~ m{ o? }xg ); or print "match: <$&>\n" while 'foo' =~ m{ o? }xg; せっかくなのでついでにもう一つ質問ですが、>>430 みたいにm付けた場合もやり方がありますか?
438 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 14:59:38 ] >>437 ないと思う mは^と$の意味が変わるだけだった気がする
439 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 15:51:17 ] なんか改行コードだけ特別扱いなんだよな
440 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 22:00:35 ] Perlのif文で質問があります。とあるデータ文書からPerlを使って情報を抜き出しているのですが、 情報1、情報2というのが存在して、情報1にヒットしたときは、情報1と情報2を出力、 情報1にヒットしないときは、無視というような判定をするにはどうすればよいのでしょうか?
441 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 22:09:09 ] perlに関係ないような気がするけど、こういう意味じゃないの? if (情報1にヒット) { print 情報1; print 情報2; }
442 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 22:12:57 ] >>441 データ文書の情報1と情報2が別々のところに記載されていてそれができないのです。 元データ文書を晒すので少々お待ちください。
443 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 22:24:18 ] 両方揃ってから判断するのだ
444 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 22:32:12 ] このデータ文書ファイルです。 uploader.moe.hm/cgi-bin/upload.cgi?mode=dl&file=2067 パス:perl 内容として作家情報と執筆した作品の情報が記載されています。 このファイルでは3名しか載っていませんが、実ファイルは世界中の作家情報が載っているので、 数万単位で同じような情報が載っています。 この中から、SCHOOLの行にUOFTOKYOと書いてある作家の作品だけを抜き出して出力できるようにしたいです。
445 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 22:35:10 ] DB_FileとかDBI使えばいいのに……Plain/textとはまた面倒な
446 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 22:53:34 ] >>444 schoolがuoftokyoの作家の名前を抜き出し、 その名前から違う場所にあるデータを抜き出して出力したいってこと? 大して>>441 とやること変わらない気がするな if (情報1にヒット) { 作家名から情報2を取得; print 情報1; print 情報2; } こうなるだけじゃない?
447 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 22:57:06 ] >>446 仰る通りです。 コードを書いているのですが、情報1にヒットした後、 情報2を書き出してやると、UOFTOKYO以外の作家作品情報も出力されてしまい、 どうしていいのか分からない状態です。
448 名前:デフォルトの名無しさん mailto:sage [2010/05/23(日) 23:13:39 ] >>447 情報2のデータの取得方法がおかしいんじゃいの? そっちはどういうデータなの?