Perlコーディング初心者質問スレ Part 56
■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん
2007/09/16(日) 19:49:43ID:???【投稿する際の注意】
質問するときは内容をよく吟味してから投稿してください。
「コマンドの意味がわかんない」とかはマニュアル見ましょう。
回答者さんは何でも屋じゃありません。
1: 自分はこういう事がしたい。
2: それでこんな風にやってみたが・・・
3: こんなエラーが出て上手く行かなかった。
最低でも1と3が無いと誰も答えられないよ。
良い回答は良い質問から。一緒に勉強しましょう。
お勧めサイトは >2 以降
前スレ ttp://pc11.2ch.net/test/read.cgi/php/1180492441/
過去ログ倉庫 ttp://user.ftth100.com/mirrorhenkan/perl/
0686nobodyさん
2008/01/07(月) 21:15:48ID:XSyaqzwgおぉ いきました!
詳しい原因はよくわからないですが、ありがとうございました。
0687nobodyさん
2008/01/07(月) 21:22:49ID:???(* 200 0.29)
ってしてみたら57.99999999999999だってさ。機械の計算って難しいことがあるな
0688nobodyさん
2008/01/07(月) 22:41:02ID:???0689nobodyさん
2008/01/07(月) 22:44:33ID:???0690nobodyさん
2008/01/07(月) 23:59:36ID:???少なくとも俺は浮動小数点の丸め誤差については習ったことない。
あと高校の世界史も。
0692nobodyさん
2008/01/08(火) 00:31:05ID:k+nta2fcコンピュータの中で200*0.29ってどうやって計算してるか分からない
そもそも結果が57.9999・・・・になると言われても、どういう計算をしているのか
さっぱりw
0693nobodyさん
2008/01/08(火) 00:34:28ID:???(* 20 0.29)
これは5.8って表示されるから困るw
0694nobodyさん
2008/01/08(火) 00:38:53ID:???0696nobodyさん
2008/01/08(火) 08:15:35ID:???wikipediaにも載ってたね。
問題の解決には、 use bignum; つかえばいいわけで、それでいい
のは分かるけれど、それとは別の話で、小数を100倍して整数で演算をして、
あとで100で割ったりする方法だったらちゃんとでるから
use bignum; しなくてもいいんだよね?
0697nobodyさん
2008/01/08(火) 22:01:08ID:???0.29が有効数字2桁だとあらかじめ分かっているなら100倍すればいいけどなあ。
既知でないときにはuse bignum;じゃないか?
0698nobodyさん
2008/01/09(水) 00:10:32ID:???レスサンクス。
いや、意味の無い部分の考えかなと思ったんだけど、
そっちの方がメモリが少なくて済み、処理が早くなったりするのかなとか
思ったのよね。ま、すごく小さな世界をいっているんだろうけれど。
0699nobodyさん
2008/01/09(水) 01:01:57ID:???俺は細かい実行時間を気にしてミスをするより、コードの可読性を優先したいな。と思った。
大量のデータを扱う人から見ればふざけた態度かもしれないけどね。
0700nobodyさん
2008/01/09(水) 02:01:45ID:???0701nobodyさん
2008/01/09(水) 03:08:01ID:480klIK20702nobodyさん
2008/01/10(木) 23:51:33ID:???サブネットマスク形式のリストをマッチングさせたいんですが、
どんなループさせればいいですかね?
#判定ルーチン内
foreach (@list) {
my ($min,$max) = subnetMinMax($_);
return ($ip >= $min and $ip <= $max) ? 1 : 0;
}
としてるんですが、grep等を使ったほうが良いんでしょうか?
ループ内でサブルーチン呼ぶのがちょっと気になります。
0703nobodyさん
2008/01/11(金) 00:04:09ID:???x: return ($ip >= $min and $ip <= $max) ? 1 : 0;
o: return 1 if($ip >= $min and $ip <= $max);
0704nobodyさん
2008/01/11(金) 11:44:26ID:???何にマッチしたか全て取りたいならgrepだけど
有るか無いかだけでいいならループ回して見つけ次第結果返していいんじゃない?
0705nobodyさん
2008/01/11(金) 16:30:20ID:???0706nobodyさん
2008/01/11(金) 20:31:41ID:???なるほど。このままにしますありがとうございました。
>>705
そっか、そうですよね。
聞いてみて良かったです。
0707nobodyさん
2008/01/12(土) 13:10:11ID:???「うんこ」の前後は英数字・日本語交じりで文字数は不定です。
$_ =~ s/(うんこ)/$1でる/;
だと、うんこ〜出るの間の文字が文末にきてしまいます。
文末指定は$みたいなので
$_ =~ s/(うんこ)/$1でる$/;
としてperlを実行させると、エラーなのか、プログラムが終わりません。
0708nobodyさん
2008/01/12(土) 13:13:01ID:???$うんこ .= ’でる’
}
0709nobodyさん
2008/01/12(土) 13:38:43ID:???if (index($_, 'うんこ') >= 0){ $_=~ s/$/でる/; }
0710707
2008/01/12(土) 13:54:47ID:???全角を半角にしてやってみたりしましたが、エラーでした。
>>709
できました。ありがとうございます。
ただ、>=0の意味が分かりません。
改行は\nじゃないんですか?
0711nobodyさん
2008/01/12(土) 18:35:26ID:???0714nobodyさん
2008/01/13(日) 13:16:41ID:rzzkvCmjエロエロ言語だの
言うけどさ
俺が習ってきた主な4つの言語のなかじゃ
間違いなく一番習得が苦しかった
ぞ
つまり、学習コストは高い
Perlより習得が難しい言語ってあるの?
私見では達人レベルを目指すならC++が全言語のなかで一番習得困難
そこそこのプロレベルを目指すならPerlが一番困難(C++はそこそこのプロならまだ簡単)
0715nobodyさん
2008/01/13(日) 13:17:19ID:rzzkvCmj0716nobodyさん
2008/01/13(日) 21:52:12ID:???変数名のつけ方で悩んでいます。
たとえば、
my $title;
my $script_content_title;
my $ScriptContentTitle;
sub param{}
sub parse_URL_encoded_string{}
sub ParseURLEncodedString{}
等、色々書き方ありますが
短い方が良いのか、わかりやすい名前が良いのか、
又、大文字、小文字を混ぜて使うべきか、覚えやすい名前にするべきか、
意見ください。
賛否両論あると思いますが、極力万人受けするものを選びたいです。
長文すみません
0717nobodyさん
2008/01/13(日) 21:53:50ID:???0719nobodyさん
2008/01/13(日) 22:43:42ID:???0720nobodyさん
2008/01/13(日) 23:03:26ID:???かというところもあるからな。
例えば、関数名で html_ をつけるとそうでないものとの区別がついて
分かりやすくなるけれど、全部の関数に html_ がついてたら
逆に無意味に長いだけとなる。
ここでアドバイスが欲しかったら、その書こうとしているプログラムや
ソースをもう少し具体的にだすとかしないと話は進まないと思う。
0721716
2008/01/13(日) 23:22:17ID:???ありがとうございます。全部読みました。
基本的にはアンダースコアを使うべきだそうです。
スコープによって使い分けるのが良いみたいですね。
$Global_Data #グローバル
$tmp #局所
$LOCK_KIND #定数
>>720
プログラムの種類によって書き方が変わる、変えられるのがperlの利点かもしれませんね。
>全部の関数にhtml_
そういうのはパッケージにまとめればOKですかね。
おかげ様で書き方が頭に浮かんできました。ありがとうございました。
0722nobodyさん
2008/01/14(月) 02:09:11ID:???でもPerlプログラマは"傲慢"なので他人のコーディングスタイルを気にしません。
こんなイメージ。
0723nobodyさん
2008/01/14(月) 02:26:48ID:???ネーミング重要。(高橋メソッド風に)
でも職人芸的なところあるよねネーミングセンスって。
なかなかそこは難しい。
0724nobodyさん
2008/01/14(月) 04:10:53ID:???0725nobodyさん
2008/01/14(月) 04:15:16ID:???もう解決したみたいだけど、Perlベストプラクティスもおすすめ
ダミアン先生の盲信はいけないけど、かなりためになるYo
0726nobodyさん
2008/01/14(月) 17:41:01ID:???一般論としては、上を目指すならいろんなハッカーのコードや文章にたくさん触れることが必要。
これがなかなか大変だし難しい。
そのためにはネット上のコミュニティーやリアルのイベントにこまめに参加したり
ブログを定期的にチェックし続けないといけないから。
そういうことをしてない自称Perl使いが結構俺の周りにはいて、
そういう奴らは我流のあまりエレガントじゃないスタイルから抜け出せないでいる。
0727nobodyさん
2008/01/14(月) 18:57:12ID:4AKnbZN2メタ字が混ざっていることもあり、ちゃんと出力できません。
あらかじめファイルの中のメタ字に\を振って置くとしても、かなりの手間になりそうですし、
何か効率の良いメタ字対策はないでしょうか?
0728727
2008/01/14(月) 19:02:23ID:4AKnbZN2ファイルに入っている文字からの出力の際の
文字化けする文字の対策をお願いします。
0729716
2008/01/14(月) 20:00:43ID:???オライリーファンの俺には最高の本かもです。
>>727-728
余計な事してるからじゃないですかね?
quotemetaなんてのはどうですか?
文字コードなんかも書くと返事もらえるかも。
0730nobodyさん
2008/01/14(月) 20:08:53ID:???情報不足です。
「ファイルに入っている文字」…どんな文字? 文字コードは何?
「出力するつもり」…どこに出力するの?
「メタ字」…具体的にどの文字ですか?
「ちゃんと出力できません」…具体的にどのように出力できないのですか?
ありがちなのは、ファイルの中と、コンソールの文字コードの設定が異なっていて、文字化けしたように見えるとか。
メタ文字をいったん解釈してしまっているとか。
ヌル文字とかタブとか垂直タブとかグループセパレータとかasciiの制御コードはそもそも「文字」ではないですし。
「文字」をどう「出力」したいのかにもよります。
コードを示してはどうですか。
0731727
2008/01/14(月) 20:18:57ID:4AKnbZN2while($list = <IN>){
(undef,$name[$i],undef) = split(/:/, $list);
$i++;
}
@name = sort(@name);
while($line = <@name>){
print "<option value='$line'>$line</option>";
}
えーっと、コードはこのような感じです。
ファイルのDBにアクセスして、その中の一部を取り出しソートしてhtmlで出力するという形です。
0732nobodyさん
2008/01/14(月) 20:21:10ID:???0733nobodyさん
2008/01/14(月) 20:23:30ID:???html中で使われてる文字コードと出力してる変数の文字コードの不一致とか…
0735727
2008/01/14(月) 20:32:56ID:???ファイルをその後書き換えたりするとそれも出来なくなるのではないかと思っております。
0736nobodyさん
2008/01/14(月) 20:40:00ID:???0737nobodyさん
2008/01/14(月) 20:46:05ID:???use utf8;
binmode STDIN, ':encoding(shiftjis)';
binmode STDOUT, ':encoding(shiftjis)';
# windowsなら shiftjis -> cp932
↑やってみて
ソース中に日本語文字列書くならutf8で保存してね。
0738nobodyさん
2008/01/14(月) 20:54:55ID:???binmode IN, ':encoding(shiftjis)';
かな?
0739nobodyさん
2008/01/14(月) 20:57:33ID:???DBにアクセスしているのにファイルハンドルから@nameに格納しているとはいかに?
@nameへの格納の仕方が心許ないです。せめて以下のようにするとか。
my @name = map { (split(/:/))[1] } <IN>;
splitの対象が全角のコロンですが、perlソースと取り扱うデータの文字コードが合っていないと
間違いの元ですよ。
で、optionタグで書き出すべき文字列のリストが@nameに入っていて、それをどうしてグロブ
演算子を使っているのかわかりません。私はこんなこと一度もしたことありませんが…。
ここで、@nameの各要素がいったん解釈されてしまっていて、カタカナのソなどSJISの2バイト目の
\x5cが取り除かれてしまっています。単に
for (sort @name) {
print qq{<option value="$_">$_</option>\n};
}
でいいと思うのですが。
0740nobodyさん
2008/01/16(水) 00:34:21ID:???run_modesで定義されなかったrun_modeを指定するとエラーが発生させられてしまうのですが
未定義の場合デフォルトのrunmodeを起動させる方法は無いでしょうか?
0741nobodyさん
2008/01/16(水) 02:08:57ID:???AUTOLOAD => \&catch_my_exception,
);
0743nobodyさん
2008/01/16(水) 04:59:20ID:FWbaTTLj以下のような、引数が省略可能なサブルーチンがあるとします。
sub Func(;$\@\%) { (省略) }
このとき、引数が渡されたのか、それとも省略されたのかを
Func内で判断する方法を教えてください。
なお、そのままifに入れると偽となるような値(例えばスカラーの値が0)の場合も、
引数が渡されていると判断します。
0744nobodyさん
2008/01/16(水) 05:29:59ID:???引数の数から判定
sub Func(;$\@\%) { print scalar @_ }
Func(); # 0
Func(undef); # 1
Func(1, @hoge); # 2
0745nobodyさん
2008/01/16(水) 05:44:10ID:???ありがとうございます。
なるほど、サブルーチンを使う時は常に@_を意識しないとダメだってことですね。
0746nobodyさん
2008/01/16(水) 11:29:46ID:???@_ii
0747nobodyさん
2008/01/16(水) 14:19:16ID:Z4nycbhz0748nobodyさん
2008/01/16(水) 20:06:54ID:L/Qn1HzA入門書を見ながら「URLにパラメータを加える」というのをやりました。
〜〜/test.cgi?list=man
とURLにパラメーターをくっつけ、cgiで
&ReadParse( *form );
$sex = $form{ 'list' };
と受け取ったつもりだったのですが、結果をprintしてみると
manman
と2回表示されてしまいます。これは何が悪いのでしょうか?
0749nobodyさん
2008/01/16(水) 20:30:55ID:???0750748
2008/01/16(水) 20:51:36ID:???なんだか色々と間違ってたようです。
0751nobodyさん
2008/01/16(水) 22:40:40ID:QOevDgBW一般的なuriデコードのバグってどんな事ですか?
同じkeyに複数のvalがある場合の対処はしてます。
0753nobodyさん
2008/01/17(木) 12:39:49ID:???ドラゴンボールというのは、集めれば願いがかなうアイテムだ
それに対して、
ウンコは、いくらドッサリ集めてもウンコにしかならない
このように両者は一見似ているようで本質的に異なる
0755nobodyさん
2008/01/17(木) 17:15:28ID:???CGI.pm使うとmod_perl環境(Apache::RegistryやModPerl::Registry)で
-ParseHeadersやPerlSendHeader offしてあってもheaderを正しく扱えるので
CGIでもmod_perlでも動きます。ってプログラムが作りやすくなる。
0756nobodyさん
2008/01/17(木) 17:17:24ID:???バグってどういうこと?
引数には、ある程度想定されるものしか入らないはずなんだから、
$form{'hoge'} とか、引数として使う値に想定される正しい値が入っているかのチェックを行えばいいんじゃないの?
0757751
2008/01/17(木) 18:58:22ID:???区切り文字はCGI.pmでも&か:ですよね。
>>754
cgi側では解決できないような感じしますね。
>>755
それは良いコト聞いた。
>>756
オライリーの本読んでたら一般的にバグがあるとの事です。
CGI..pm使えとの一点張りです。
なので、どこにバグがあるのかなと ← いまここ
みなさんレスありがとうございます。
0760nobodyさん
2008/01/18(金) 12:04:46ID:Z4Jr4bliどこかいいサンプルないでしょうか?
アップロードしたいファイルはエクセルファイルです
0761nobodyさん
2008/01/18(金) 12:15:45ID:???0762nobodyさん
2008/01/18(金) 12:39:13ID:???それともファイルをアップロードするCGIなのか知らんけど
http://search.cpan.org/~gaas/libwww-perl-5.808/lib/HTTP/Request/Common.pm
http://search.cpan.org/~lds/CGI.pm-3.33/CGI.pm#CREATING_A_FILE_UPLOAD_FIELD
0764nobodyさん
2008/01/18(金) 14:27:48ID:???0765nobodyさん
2008/01/18(金) 15:13:46ID:???0766nobodyさん
2008/01/18(金) 16:38:38ID:???#!/usr/bin/perl
use strict;
use warnings;
use utf8;
use CGI qw/:standard/;
use constant MAX_WAIT => 10;
my $q = new CGI;
$q->charset('utf8');
my $wait = rand(MAX_WAIT);
my @mind = qw(uploadしたい uploadしたくない uploadしてもいい);
my $mind = $mind[ int( rand(scalar @mind) ) ];
print start_html(
-head => meta({-http_equiv=>'refresh', -content=>"10; URL=$ENV{SCRIPT_NAME}"}),
-title => 'CGIの気持ち'
),$mind,end_html;
0767nobodyさん
2008/01/19(土) 01:06:12ID:???$waitは、どこで使ってるの?
-head => meta({-http_equiv=>'refresh', -content=>"$wait; URL=$ENV{SCRIPT_NAME}"}),
とかやりたかったのか?
0768nobodyさん
2008/01/19(土) 14:38:24ID:gMv3rNuv100%の確率のうち30%が当たりという設定をして
くじを引かせる場合、
my $rate = 30;
my $atari = int((rand(100))) + 1;
if($atari <= $rate){
print "あたり\n";
}
これで30%ということに理屈ではいえるのでしょうか。
それとも上か下かなので2分の1になるのでしょうか。
ご教示いただけますと幸いです。
0769nobodyさん
2008/01/19(土) 15:04:56ID:???0770nobodyさん
2008/01/19(土) 15:25:31ID:???0771nobodyさん
2008/01/19(土) 16:00:15ID:???そういうときは、そのコードを何万回か繰り返してあたりとはずれのカウントを取って、
実際に30%くらいになるかを調べればいいんですよ。
0774nobodyさん
2008/01/19(土) 21:24:36ID:???ありがとうございます。
>>773
実行有難うございます。
私の方でもやってみましたが、平均値が30%になりました。
安心しました。
0775nobodyさん
2008/01/19(土) 23:16:40ID:???use strict;
use CGI;
use CGI::Carp qw(fatalsToBrowser);
use POSIX qw(strftime);
my $q = new CGI;
print $q->header(), $q->start_html();
#print $q->dump; # for debug
my $outputdir = "log"; # ファイルを置く先 (ディレクトリ)
my $fh = $q->param('uploaded_file');
my ($ex) = ($fh =~ m|(\.[^./\\]+)$|); # 拡張子
if ($fh ne "") {
my $timestamp = strftime "%y%m%d%H%M%S", localtime;
my $outputfn = "$outputdir/$timestamp$ex";
open(F, "> $outputfn") or die;
flock(F, 2);
if (defined $fh) {
while (<$fh>) {
print F $_;
}
}
close F;
print qq{saved as <a href="$outputfn">$outputfn</a>};
}
print $q->start_multipart_form(-name => 'myform'),
$q->filefield(-name => 'uploaded_file'),
$q->submit("OK"),
$q->endform,
$q->end_html(), "\n";
0776760
2008/01/19(土) 23:18:40ID:???日本語おかしかったですね、すいません。
サンプルを探したんですが
>>775のままだったら
ファイルをアップしたときにファイル名が
アップロードした日付になってしまいます。
ファイル名を変更することなくアップロードするにはどうすればいいでしょうか?
0777nobodyさん
2008/01/20(日) 00:14:39ID:1RDcSYMgのところを、そうじゃなくすれば良い。
0779nobodyさん
2008/01/20(日) 02:12:08ID:???0780nobodyさん
2008/01/20(日) 03:03:09ID:???同名ファイルの処理が必要になるし、文字化けとかあるし。
文字化けとかしたら、ダウソとか出来なくなる場合もあるし、
削除とかはsshログインして * とか使って消さないといけなく
なる場合もある。(解決は出来るから問題なしともいえるのだが)
日本語はファイルと一緒にコメントとして管理すべきだと思うけど、
どうかな?
0782nobodyさん
2008/01/20(日) 19:19:48ID:xw354eHRopen(OUT, ">$filename");
binmode(OUT);
while (read($fh, $buf, 1024)) { print OUT $buf; }
close(OUT);
close($fh);
上記なソースをよく見かけるんだけど、
三行目で一気に処理するんじゃなくて、
1024バイトずつ取り出して処理する理由って何?
0783nobodyさん
2008/01/20(日) 19:21:07ID:???0784775
2008/01/20(日) 19:37:21ID:???具体的にどうかえればいいのでしょうか?
教えてくださいとはいいません。
やってください
>>780
ご意見ありがとうございます。
0785nobodyさん
2008/01/20(日) 20:21:40ID:???■ このスレッドは過去ログ倉庫に格納されています