Perlコーディング初心者質問スレ Part 38
■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん
04/10/07 23:23:08ID:kiEzDCJF【投稿する際の注意】
質問するときは内容をよく吟味してから投稿してください。
「コマンドの意味がわかんない」とかはマニュアル見ましょう。
回答者さんは何でも屋じゃありません。
1: 自分はこういう事がしたい。
2: それでこんな風にやってみたが・・・
3: こんなエラーが出て上手く行かなかった。
最低でも1と3が無いと誰も答えられないよ。
ソース貼る時は、全角スペースでインデント忘れずに。
良い回答は良い質問から。一緒に勉強しましょう。
過去ログやお勧めサイトは >>2-10
006862
04/10/11 01:38:46ID:21NinhMEわかりました。あの後、ラクダ読んでなんとなく
感覚が掴めました。ありがとうございました。
0069nobodyさん
04/10/11 17:04:09ID:???漏れは直さないでそのまま使えてるんだけどなんで一般的に直す必要があるのでしょうか?
0070nobodyさん
04/10/11 17:30:37ID:???スレ違い。
http://pc5.2ch.net/test/read.cgi/php/1095633323/
http://www.studyinghttp.net/cgi-bin/rfc.cgi?2616
0071nobodyさん
04/10/12 00:56:44ID:J8ZBB7PX掲示板のCGIを作ってる最中なんだけど、
(1)全ての書き込みを一つのログファイルにする
(2)書き込み毎にログファイルをつくる
ログが1000件あると仮定して10件を表示する場合、どちらの方がリソース食うだろう?
(1)の場合、処理手順は少ないが余計なデータを大量に読み込む。
(2)の場合、opendir、readdirでファイル名を読み込み、かつ各々のファイルを読み込むので、
処理は繁雑になるが余計なデータをメモリ上に展開しない。
はやりシステムとのやり取りが多くなる(2)の方がコスト高いのだろうか?
0072nobodyさん
04/10/12 00:59:02ID:???スレ違い。
http://pc5.2ch.net/test/read.cgi/php/1034645635/
0073nobodyさん
04/10/12 01:04:57ID:???儂のケースでは、データーが300件ぐらいで使ってたフリー鯖でゴルァされたのでsql導入した。
0075nobodyさん
04/10/12 01:29:03ID:???seekで位置決めしてread,writeってのもあり。
0076nobodyさん
04/10/12 01:35:04ID:???レスありがとうございます。とりあえず、一般的(と思われる)(1)の方法でやってみます。
データは可変長ですが、固定長にしてoffsetで狙い撃ちもアリですね。ちょっと工夫してみます。
>>73
すいません。そのスレ知りませんでした。
0077nobodyさん
04/10/12 01:52:29ID:???0078nobodyさん
04/10/12 10:44:09ID:???open IN,$dat.dat
@var[50..60]=<IN>
これは$dat.datを全部読んでいるんですか?それとも60行目で処理が終了しますか?
0079nobodyさん
04/10/12 11:21:32ID:???0080nobodyさん
04/10/12 11:27:40ID:???読むことは読むけど、速いことは速いんじゃない?
今のCPUで読み込みファイルの大きさで遅いってことは、普通の取り扱う範囲の
テキストファイル(1M以下程度)だとあり得ない希ガス。
Perlが一番遅いのって、「値のコピー」周辺だと思うんだけどネェ。
(特にリスト系)
まぁ、ファイルの大小と、スライス有・無でベンチとってみれヴぁ?
0081nobodyさん
04/10/12 11:47:38ID:???前スレにファイルの扱いの方が遅いと書いてあった希ガス
よほどたいそうなモン作らない限りは誤差の範囲だろ
0082nobodyさん
04/10/12 11:59:34ID:???これの作り方教えて下さい
0083nobodyさん
04/10/12 12:11:37ID:???0084nobodyさん
04/10/12 15:01:19ID:???出力結果の見方がわかりません。
テンプレにはベンチマーク関連の資料が見当たらないのですが、
見方などが載っているサイトをご存知の方いませんか?
0085nobodyさん
04/10/12 16:54:23ID:???>>3
http://perldoc.com/perl5.8.4/lib/Benchmark.html
http://pc5.2ch.net/test/read.cgi/php/997829243/
出力のどの部分が分からんのか具体的に示した方がいいよ。
0086nobodyさん
04/10/13 12:37:35ID:SrofvYG0ただし、$p1 〜 $p7はそれぞれ違う数字になるように代入したい
と思い、こんなコードを考えたのですが
008786
04/10/13 12:38:00ID:SrofvYG0$p2 = int(rand 7);
while($p1 == $p2){
$p2 = int(rand 7);
}
$p3 = int(rand 7);
while($p1 == $p3 or $p2 == $p3){
$p3 = int(rand 7);
}
$p4 = int(rand 7);
while($p1 == $p4 or $p2 == $p4 or $p3 == $p4){
$p4 = int(rand 7);
}
$p5 = int(rand 7);
while($p1 == $p5 or $p2 == $p5 or $p3 == $p5 or $p4 == $p5){
$p5 = int(rand 7);
}
$p6 = int(rand 7);
while($p1 == $p6 or $p2 == $p6 or $p3 == $p6 or $p4 == $p6 or $p5 == $p6){
$p6 = int(rand 7);
}
$p7 = int(rand 7);
while($p1 == $p7 or $p2 == $p7 or $p3 == $p7 or $p4 == $p7 or $p5 == $p7 or $p6 == $p7){
$p7 = int(rand 7);
}
008886
04/10/13 12:38:40ID:SrofvYG0p1〜p100までに1〜100までの数字をそれぞれ違う数字が入るようにするなんてするとひどいコードになる事に・・・
うまくループ構文使えばもっと簡単なコードになる気がするのですが
私では作れませんでした・・・どなたかご存知でしたら教えていただけますでしょうか。
(ちなみになぜこんな事をやりだしたかというと、特定個数の全てのアイコンを毎回順序をランダムで表示したいと考えたからです)
連続カキコすいません。(改行エラーでたので)
0089nobodyさん
04/10/13 12:41:40ID:???例えば、普通にリンクを貼るだけならできるのですが、
自サイトへはinner、他サイトへはouterというスタイルを適用したいと思っています。
ログの例:(MyIDを含むのが自サイトとします)
http://localhost/MyID/<BR>http://www.2ch.net/
出したい出力結果(HTML上):
<A href="http://localhost/MyID/"class="inner">http://localhost/MyID/</A><BR><A href="http://www.2ch.net/" class="outer">http://www.2ch.net/</A>
sub link { # 引数に渡すのはログ全体
$_[0] =~ s/([^=^\"]|^)((http|ftp|https)\:[\w\.\~\-\/\?\&\+\=\:\@\%\;\#\,\|]+MyID[\w\.\~\-\/\?\&\+\=\:\@\%\;\#\,\|]+)/$1<A href="$2" class="inner">$2<\/A>/g;
$_[0] =~ s/([^=^\"]|^)((http|ftp|https)\:[\w\.\~\-\/\?\&\+\=\:\@\%\;\#\,\|]+)/$1<A href="$2" class="outer">$2<\/A>/g;
}
こう記述すると、前者も後者も全てouterになってしまいます。
if ($_[0] =~ /MyID/) {
$_[0] =~ s/([^=^\"]|^)((http|ftp|https)\:[\w\.\~\-\/\?\&\+\=\:\@\%\;\#\,\|]+MyID[\w\.\~\-\/\?\&\+\=\:\@\%\;\#\,\|]+)/$1<A href="$2" class="inner">$2<\/A>/g;
} else {
$_[0] =~ s/([^=^\"]|^)((http|ftp|https)\:[\w\.\~\-\/\?\&\+\=\:\@\%\;\#\,\|]+)/$1<A href="$2" class="outer">$2<\/A>/g;
}
こうすると、今度は自サイトへのリンクは貼られるのですが、他サイトへのリンクは貼られなくなってしまいます。
上記の出したい出力結果を出すには、どのように記述したらよいのでしょうか。
009186
04/10/13 13:33:52ID:SrofvYG0配列ってランダマイズできるんですか・・・。
知りませんでした汗
ありがとうございました。探してやってみます。
0092nobodyさん
04/10/13 13:44:56ID:???@array=();
for ($count = 0; $count < 7; $count++) {
push(@array,$count);
}
&shuffle( \@array );
sub shuffle {
my $array = shift;
my $i;
for ($i = @$array; --$i; ) {
my $j = int rand ($i+1);
next if $i == $j;
@$array[$i,$j] = @$array[$j,$i];
}
}
&shuffleを呼び出す前と、呼び出した後で@arrayの中身を見てみよう。
0094nobodyさん
04/10/13 15:22:33ID:???@outにランダムな数値を出力。
@in = (1 ..100);
@out = ();
srand;
foreach (@in) {
my $r = int rand (@in + 1);
push(@out, $in[$r]);
$out[$r] = $_;
}
0096nobodyさん
04/10/13 15:48:10ID:???srand(time());
%hash = map {$_ => rand()} 0 .. 6;
@array = map $_, sort {$hash{$a} <=> $hash{$b}} keys(%hash);
print "@array\n";
0097nobodyさん
04/10/13 16:04:53ID:???List::Utilのshuffle使うな
0098nobodyさん
04/10/13 16:07:16ID:???モジュールに頼りっきりになるのもアレだが、でも使えるものは使っていきたいよね。
0099nobodyさん
04/10/13 16:11:23ID:???↑の配列の中から18に一番近い数字を取り出すみたいなのはどうしたらいいでしょうか?
0100nobodyさん
04/10/13 16:20:30ID:???$seed =18;
$tmp = $seed;
@data = (12,15,20,50);
for(@data){
my $diff = abs($_ - $seed);
$min = $_ if($diff <= $tmp);
}
print $min;
こんなんでどない?
010199
04/10/13 16:24:16ID:???$seed =18;
$tmp = $seed;
@data = (12,15,20,50);
for(@data){
my $diff = abs($_ - $seed);
if($diff <= $tmp){
$min = $_;
$tmp = $diff;
}
}
print $min;
0102nobodyさん
04/10/13 16:27:05ID:???abs($_ - $seed);が0の時はlastで抜けちまった方が良さげ
0103nobodyさん
04/10/13 16:32:45ID:???0104nobodyさん
04/10/13 16:37:15ID:???reduce {abs($a-$seed)<abs($b-$seed)?$a:$b} @data
010586
04/10/13 18:17:10ID:???書いていただいた全てのコードが勉強になりました。
一つ一つ検証して試してみたいと思います。
0106nobodyさん
04/10/14 00:02:36ID:pD0/ztzCforなどで一個一個数えていくしかないのでしょうか?
010889
04/10/14 00:15:43ID:???それともこういうのは理論上無理なんですかね・・・
0109nobodyさん
04/10/14 00:33:02ID:???'C,3,青紫',
'B,4,赤',
'C,6,青',
'A,7,緑',
'A,9,紫',
'B,10,黄');
こんな感じである配列の先頭にあるa,b,cの数を数えて
連想配列に
%count = (A,3,
B,1,
C,2);
こんな感じに持って行くにはどうしたら良いんでしょう?
0110nobodyさん
04/10/14 00:46:44ID:???という配列のなかから一番多いものだけを取り出すってのはどうしたらいいですか?
この中だとりんごに当たりますね。
0111nobodyさん
04/10/14 00:49:57ID:???0113nobodyさん
04/10/14 01:31:30ID:???まずurlにマッチングさせてからinnerかouterか判定させれば?
urlの正規表現についてはググればすぐに出てくるので。
あと、エスケープする必要があるものとそうでないもの調べてくれ。
0114nobodyさん
04/10/14 02:27:52ID:???ここはアルゴリズムを質問するスレではない。
「こういうアルゴリズムを考えたので Perl で実装したいんですが
どうコーディングしたら良いですか?」
という質問形式にして出直してきたまえ。
例えば、いったん各々の個数を全部数え上げるというアルゴリズムで行くなら、
ハッシュをインクリメントしていって、数え終った後でソートする、というのが素直だろうな。
0115nobodyさん
04/10/14 05:34:49ID:???0116nobodyさん
04/10/14 06:51:34ID:ETIFZxwkNet::SSH::Perlを使ってサーバに入り、任意のメールアドレスに対してメール
を送信するスクリプトを作る。
【スクリプト】
#!/usr/bin/perl -w
use Net::SSH::Perl;
$host = "www.test.net";
$user = "hogehoge";
$pass = "2ch_test";
$cmd = "mail hoge\@hoge.ne.jp";
$body = "www.test.net is ok\n";
$ssh = Net::SSH::Perl->new($host);
$ssh->login($user, $pass);
$ssh->cmd($cmd);
$ssh->cmd($body);
【説明】
スクリプトを実行したとき、指定したサーバにログインすることはできるので
すが、それ以上処理が進まず、メール送信もされません。ただ、スクリプトを
実行させてキーボードから文字を入力してCtrl-Cで処理を中断するとメールは
配信されます。
[mona@localhosst mona]% ./test.pl<Enter>
これはテストです。<Enter>
Ctrl-C
【教えて欲しいこと】
$bodyの内容を自動的に標準入力に代入し、メールを送信する。
加えて、サーバからの切断も自動的に行ってくれる。
以上の二点を解決したいです。
よろしくお願いします。
0117nobodyさん
04/10/14 08:14:10ID:???for(@a){
@b = split / | /; #全角or半角スペースで切る
}
for(@b){
print;
}
というコードを実行すると何故か
ゼ
と表示されます。これはどういうことでしょうか?
$aの「ァー」の部分を色々変えてみましたが、
こうなるのは「ァー」と「ぁー」です。
どなたか分る方いたら教えてください。
0118nobodyさん
04/10/14 08:36:03ID:eMIY0T+Hの表はユーザーエージェントの解説なのですが、表の一番下にあるような
「J-PHONE/4.0/J-SH51/SN*********」という文字列で、
SN以降を削除し他の部分だけを残したいんです。その場合の正規表現は
どう書けばいいのでしょうか?
$abc =~ s/(.+)[SN](.+)/$1/; だとダメでした。どなたかお力添えをお願いします。
0120nobodyさん
04/10/14 10:36:01ID:???たぶんソースをeucで書いてるだろうから、
use encoding 'euc-jp';
を頭に追加すれば直ると思うが。
unicode機能を有効にしないperlでは日本語の2バイトコードは
1つの文字としては扱えず、1バイトずつバラバラのバイト列と
なってしまう。
"ァー" = "\xa5\xa1\xa1\xbc"
/ | / = /\xa1\xa1| /
なので、ァーの部分は真中の\xa1\xa1の部分を区切りとして
splitされてしまい、\xa5\xbcが出力される。これは「ゼ」。
同様に「ぁー」のときは「ぜ」になってるはず。
0121nobodyさん
04/10/14 10:38:58ID:???http://www.din.or.jp/~ohzaki/perl.htm#JP_EUC_JP
ここから下を読むことを勧める。
0122118
04/10/14 10:39:49ID:eMIY0T+Hレスありがとうございます。
でもそれではうまく行きませんでした。
SN以降が削除されずにそのまま出力されているようです。
0123118
04/10/14 10:43:11ID:eMIY0T+H感謝感謝です。ありがとう。
0125117
04/10/14 12:42:18ID:???コードはEUCで書いてるのですが
扱ってるデータがS-JISだったりします。
use encoding 'euc-jp';
したら、データが化けてしまいます。
そういう場合
:コードの文字コードと 扱ってるデータの文字コードが違う場合:
どう対処したらよいのでしょうか?
0128nobodyさん
04/10/14 13:45:02ID:???最低限の検索ぐらいはやった上で質問しなきゃ。
コーディングでググれば?
検索わからない?
http://pc6.2ch.net/pcqa/
0131117
04/10/14 14:05:05ID:???http://www.din.or.jp/~ohzaki/perl.htm#JP_Trans
にそのまんま答えが書いてありました。
お騒がせいたしました。
0132nobodyさん
04/10/14 17:55:56ID:8JHhLpH4は
my *takesi;
と同じと考えてよろしいでしょうか?
0133nobodyさん
04/10/14 18:02:41ID:???コーディング 【coding】
プログラミング言語を使ってソフトウェアの設計図にあたるソースコードを作成すること。
(e-Wordsより)
>>126は何故に>>125に対してこれを読めって言ったの?
文字コード問題は設計とは関係ないってか?そんなアホな事はないよな。
そもそもよほどのことでない限りコーディングと無関係にはなれないんだがな。
例えば俺の話とかなwww完全にすれ違いってやつだ。
まあお前ら少しは言葉の勉強もしろよ。
0136nobodyさん
04/10/14 23:56:21ID:mdncFzXxこの shift ってどういう意味なんでしょうか?
関数ですか?
0137nobodyさん
04/10/15 00:34:17ID:???$c = "にちわ"
変数$aに$bと$cを結合したもの、つまり
"こんにちわ"を代入するには
$a = $b.$c
で大丈夫でしょうか?
0138nobodyさん
04/10/15 00:39:03ID:???>>137と似てるんですが、
$b = "co"
$c = "jp"
の場合に $a に co.jp を代入するにはどうすればいいですか?
$a = $b\..$c
で合ってます??
0142nobodyさん
04/10/15 08:34:27ID:???何スレぐらいかかるだろうか。
0143nobodyさん
04/10/15 08:35:47ID:0zK8noVIlog.txtを編集するために
bbs1.cgiでflockした場合
bbs2.cgiで編集しようとした時にも
ロックされてるんですか?
0144nobodyさん
04/10/15 10:12:58ID:???shift (@data);
とかならわかるんですけど、
スカラー = shiftという意味がわからないのです。
0145nobodyさん
04/10/15 10:54:53ID:???という文のみのファイルを作って、プラウザからアクセスすると指定URLに飛びますが、
上記の文より前に
print "Content-type: text/html\n\n";
などと書かれていると、ブラウザ上に「Location: http://www.2ch.net/」という文字列が表示されてしまいます。
やりたい事は、フォームから検索をかけて、検索処理中の間は特定のページを表示して、
検索が終了したらその結果を表示する画面に遷移する、ということです。
「検索処理のリクエストを受ける → 特定のページを出す「お待ちください」など → 検索終了 → 結果表示」
要するに、1回のPerlの処理で、ブラウザ上で複数のページ間を遷移させる事は可能でしょうか。
0146nobodyさん
04/10/15 11:09:31ID:???マニュアルのshiftの項をよく読め。
ttp://perldoc.jp/docs/perl/5.6.1/perlfunc.pod とか。
0148nobodyさん
04/10/15 13:29:36ID:???例えば
<meta http-equiv="Content-Type" content="text/html; charset=Shift_JIS">
<meta http-equiv="Content-Style-Type" content="text/css">
<meta http-equiv="Content-Script-Type" content="text/Javascript">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="pragma" content="no-cache">
を、
print "Content-type: text/html; charset=Shift_JIS\n";
print "Content-Style-Type: text/css\n";
print "Content-Script-Type: text/Javascript\n";
print "cache-control: no-cache\n";
print "pragma: no-cache\n\n";
にした場合、きちんと返ってるのでしょうか?
0149nobodyさん
04/10/15 13:33:40ID:???0150nobodyさん
04/10/15 13:45:29ID:???0151nobodyさん
04/10/15 13:55:55ID:???0152nobodyさん
04/10/15 14:55:30ID:???一点目のアドバイス。
「きちんと返っているかどうか確認する方法を教えてください」と質問すれば
いじめられることもなかっただろうに。
二点目のアドバイス。
どっちにしても Perl と全く関係ない質問なので、
WebProg初心者スレなどで聞く方が正解。
0153nobodyさん
04/10/15 15:35:31ID:???bbs2.cgiがflock使うなら勿論ロックになる。
flockはセマフォでの唯一のロック獲得争いにすぎない。
そのロックしないプログラムには通用しない。
0155nobodyさん
04/10/15 16:21:08ID:???bbs.cgiでlog.txtに書き込みするためロックしました
そのままdelete.cgiでlog.txtの書き込みの一部を削除しようとした場合には
ロックはされてないということでいいんですか?
0156nobodyさん
04/10/15 16:57:04ID:???カギのかからないトイレのドアに使用中と札を下げるようなもの。
その札を見てくれる奴には効果はあるが、ハナから見ちゃいねー
奴には無効。delete.cgiがどっちの奴かはオレにはわからない。
0157nobodyさん
04/10/15 17:40:29ID:???delete.cgiが、flockでlog.txtに対するロックを獲得しようとすれば、ちゃんと排他制御がなされる。
(bbs.cgiがロックを返すまで待つか、即座に獲得失敗するかはモード次第)。
しかし、delete.cgiがflockを行っていないのなら、bbs.cgiによる排他制御は無意味。
bbs.cgiがロックを得ている・得ていないに関わらず操作可能。
flockは、お手軽なロック機構にすぎない。
(ロック用ディレクトリとか、スリープするか即座に失敗させるかを自力でやらなくて良いって程度のもの)。
0158nobodyさん
04/10/15 17:49:21ID:???http://pc5.2ch.net/test/read.cgi/php/1024795138/
0159nobodyさん
04/10/15 17:55:33ID:???>flockはセマフォでの唯一のロック獲得争いにすぎない。
これは勘違いだったようだ。perlのflockがセマフォ使ってるわけじゃないか。
もう氏ぬ。
0160nobodyさん
04/10/15 20:46:48ID:M3+xPf5Cどうしたらいいのでしょうか? 普通はブラウザのボタンから起動されると
思うのですが、ある時間が来ると自動で動かしたいのです。よろしくお願いします。
0162nobodyさん
04/10/15 23:13:44ID:???下の下の方(flock(2)やfcntl(2)の下のほう)ではセマフォつかってるよ。多分。
それでも↓は意味不明だけど。
> >flockはセマフォでの唯一のロック獲得争いにすぎない。
0163nobodyさん
04/10/16 02:52:59ID:???どちらも実行ステップは100だとしても、やはり後者の方がサーバに対する
負荷は少ないのだろうか。
0164nobodyさん
04/10/16 03:14:53ID:???0166nobodyさん
04/10/16 12:33:14ID:???計測の方法が分かりません。。。
ググったらWin鯖は無理と書いてあったんですが、Win鯖で出来るソフトありませんか?
0168nobodyさん
04/10/16 21:45:26ID:???ちゃんと排他は行われるでしょうか?
■ このスレッドは過去ログ倉庫に格納されています