Perlコーディング初心者質問スレ Part 38
■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん
04/10/07 23:23:08ID:kiEzDCJF【投稿する際の注意】
質問するときは内容をよく吟味してから投稿してください。
「コマンドの意味がわかんない」とかはマニュアル見ましょう。
回答者さんは何でも屋じゃありません。
1: 自分はこういう事がしたい。
2: それでこんな風にやってみたが・・・
3: こんなエラーが出て上手く行かなかった。
最低でも1と3が無いと誰も答えられないよ。
ソース貼る時は、全角スペースでインデント忘れずに。
良い回答は良い質問から。一緒に勉強しましょう。
過去ログやお勧めサイトは >>2-10
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:???ちゃんと排他は行われるでしょうか?
0169nobodyさん
04/10/16 23:05:32ID:???# カウントファイルの読み込み
open(FILE, "+<./count.dat") or die("エラー:カウントファイルが開けません");
eval{ flock(FILE, 2);};
$count = <FILE>;
# カウントファイルの書き込み
seek(FILE, 0, 0);
print FILE ++$count;
close(FILE);
# サーバ出力
print <<END;
Content-type: text/html
中略)
END
Apachでエラーログをみると Premature end of script headers と出てしまいます。
どの部分を訂正すればよいのでしょうか?ご存知の方、ご指導お願いします。
0170nobodyさん
04/10/16 23:13:07ID:???Content-type: text/html
中略)
0171nobodyさん
04/10/17 01:00:06ID:???このdieの部分はどこに出力されるのですか?ログとか?
0172nobodyさん
04/10/17 01:03:49ID:???0173nobodyさん
04/10/17 01:38:29ID:sz1VkLQM$dbh->{NAME}
が配列へのリファレンスだとして、
$dbh->{NAME}->[0]ではアクセスできる状態です。
foreach($dbh->{NAME})
{
print;
}
foreach($$dbh->{NAME})
{
print;
}
等とやってもうまくいきませんでした。
0174nobodyさん
04/10/17 01:39:32ID:???0176nobodyさん
04/10/17 10:10:48ID:???中略)の部分は
<html>
<head><title>perlアクセスカウンター</title></head>
<body>
<P>あなたは$count番目の訪問者です。</p>
</body>
</html>
END
Premature end of script headers
エラー:カウントファイルが開けません のエラーログが出ます。
open or die の文がおかしいのかと思ったのですが、良くわかりませんでした。よろしくお願いします。
0177nobodyさん
04/10/17 10:20:37ID:???Content-type:text/htmlの後に改行が2つ(\n\n)必要だった希ガス
0178nobodyさん
04/10/17 10:21:41ID:???0179nobodyさん
04/10/17 13:45:28ID:???双方が協調して動作するためには、同じ方式のロックメカニズムを使用する必要があるが、
perlのflockはOSが提供しているflockとは限らない、PHPは知らない。
プラットフォームインディペンデントに作るなら、昔ながらのロックファイル方式か、
OSの提供する排他制御のプリミティブを直接呼び出すのがいいだろう。
0180nobodyさん
04/10/17 22:56:51ID:???0183180
04/10/18 01:23:59ID:???0184nobodyさん
04/10/18 04:17:33ID:???sub a
{
my $daskin;
$daskin="かきくけこ";
&b;
&c;
}
sub b
{
my $daskin;
$daskin="あいうえお";
}
sub c
{
print "$daskin";
}
こういったスクリプトを書いた時、&a、&b、の中で$daskinは局所化されているので
&c内のprintの表示が空になることを期待していたのですが、「あいうえお」と表示されてしまいます。
変な質問ですが、みなさんにとっては納得のいく結果でしょうか?
私の局所化処理が間違っている場合、教えて下さいm(__)m
0185nobodyさん
04/10/18 05:07:01ID:???自己解決いたしました。
上記のスクリプト、ここへの転載も含め、私の記述が間違っていたようです。
0186nobodyさん
04/10/18 13:44:39ID:???メッセージ:
$message
ここまで
EOF
こういう記述があるとして、$messageにはランダムにメッセージが入るのですが、
ここに何も文字列が入らなかった場合、HTMLで見ると
メッセージ:
ここまで
このように、間が空行になってしまいます。
ここを上手く詰められるような記述方法は無いでしょうか。
0187nobodyさん
04/10/18 13:54:10ID:???メッセージ:
$messageここまで
EOF
0189nobodyさん
04/10/18 18:54:11ID:???sprintf("%s, %02d-%s-%4d %02d:%02d:%02d GMT",
$day,$mday,$mon,$year+1900,$hour,$min,$sec);
というような形にしたいのですが、曜日だけが変換のネックと
なっています。どのようにこの日の曜日を計算させればよいの
でしょうか?
0191nobodyさん
04/10/18 21:38:36ID:???2.http://bbb.b.b/b/cgi
1のプログラム上から引数を渡して2のプログラムを動作させて
結果を1のプログラムに返すようなことって可能でしょうか?
2のサーバーのローカルにあるデータベースからデータを取得して
1のサーバーのローカルにあるデータベースにデータを保存したいと
おもっております。 言語はperl使用です。
0193nobodyさん
04/10/19 10:09:36ID:???何スレも前で既出のもんとかを既出の一言で片付けられたってわかるわけねーだろアフォ
どうせ本当に既出かどうかの確認もしてねぇんだろ?(pp
ん?何スレ目で話題が出たか言えるか?無理だろうなぁ日本語読めてないっぽいもんなぁ(・∀・)ニヨニヨ
0196nobodyさん
04/10/19 14:27:41ID:IcRPasE8request() とrequest()の間ってやっぱsleepとか入れて間を開けた方がいいのでしょうか?
具体的には ヤフーの株価データなんですけど
0198nobodyさん
04/10/19 17:42:02ID:6g0jZqZR0199nobodyさん
04/10/19 17:45:10ID:???0200nobodyさん
04/10/19 19:19:06ID:???0201nobodyさん
04/10/19 20:44:07ID:AGmXypRw現在、ADSLですが、DDNSは使っていないので、固定Webアドレスが保証できない状態です。
ADSLモデムのルーター機能を通していますので、当然ルーターにグローバルIPが振られてます。
では、プライベートIP上のCGI実行Progでこのルーターのグローバル
IPを得ることはできます?
あるperlのCGI実行スクリプトがWebサーバー上のフォルダへのフルパス(http://〜)
を要求しているので、グローバルIPが固定でない場合ですから、その都度prog的にIPを取得すれば使えるのでお願いします。
win me
AN HTTPD
ActivePerl5.8.4
です。
0202nobodyさん
04/10/19 20:57:26ID:???ページの取得にはLWP使用。
0203nobodyさん
04/10/19 21:25:04ID:???片方ではcommon.plというところでとまってしまいます
片方ではすんなり動きます
おそらく何か重要な部分を設定ミスしてると思うのですが
わかる範囲でチェックをしたつもりなのですが
1から重要な場所をチェックできるようなサイトをどなたかしりませんか?
もしくは直感的にどこが悪いか指摘していただいても結構ですので
よろしくお願いいたします。
0204nobodyさん
04/10/19 21:36:22ID:???0205201
04/10/19 22:15:51ID:???ありがとうございます。
ルーター設定ページを読み込んで、読み取る方法も確かにそれもありですね
ベタですね。確かに^^
おそらくActivePerlなので、Win用ActiveXコンポーネント(dllなど)が利用できるので
できますよね。WIN32APIも呼べるはずですが、…そのサンプルを今探しております。
P…面倒だからやはりDDNSか固定IP…
いやがんばります。できたら報告致します・
0206nobodyさん
04/10/19 23:13:46ID:???0208nobodyさん
04/10/20 04:50:52ID:aP/RN7icそれだけじゃわかんない。
0209nobodyさん
04/10/20 10:36:58ID:???for($i=2;$i>0;$i--){
if (rename("file.unlock","file.lock")) {last;}
}
if($i<0){
die "Failed file lock";
}
処理
rename("file.lock","file.unlock");
これに「異常終了しファイルロックが1分以上かかっていたら修正する」という処理を入れたいんですが、どんな方法がありますか。
0210nobodyさん
04/10/20 10:41:01ID:???条件が $i>=0 です。
0211nobodyさん
04/10/20 11:05:53ID:???http://www.din.or.jp/~ohzaki/perl.htm#File_Lock
http://pc5.2ch.net/test/read.cgi/php/1097158988/
0212203です
04/10/20 11:51:17ID:???現在mein.cgiというのを動かしているのですが
# CGI 初期設定のインポート
require"../config/default.cfg";
# 変換ライブラリのインポート
require"../common/jcode.pl";
# CGI共通ライブラリのインポート
require"../common/common.pl";
という順番でrequireしていっています
片方では問題なくcommon.plはとおるのですが、片方では
さばのログを読む限りではcommon.plを読み込んでいる最中に
500エラーとなってとまってしまっています。
ちなみにエラーで止まる部分は
この部分→use Date::Calc qw(Delta_DHMS);
my($days, $hours, $min, $sec) = Delta_DHMS($young_year, $young_mon, $young_day, $young_hour, $young_min, $young_sec,
$old_year, $old_mon, $old_day, $old_hour, $old_min, $old_sec);
です。
0213nobodyさん
04/10/20 12:12:49ID:???貼った方がいいと思うけどな...
0215nobodyさん
04/10/20 12:31:34ID:???0216nobodyさん
04/10/20 12:36:07ID:???0217nobodyさん
04/10/20 13:28:26ID:???ありがとうございました
0218nobodyさん
04/10/20 13:40:35ID:???0219203です
04/10/20 13:43:29ID:???Date::Calc
のモジュールが入っていませんでした
どうもお騒がせしました
0220nobodyさん
04/10/20 14:01:44ID:???事故解決したようだが、注意しとく。
まずひとつめ。「BEGIN failde」なんてなってるところからして
コピペじゃなくて手打ちしただろ? 手打ちは間違えて混乱のもと
になるのでこういうときはできる限りコピペするのが基本。どう
してもできないときはしょうがないが、鯖のログなら普通コピペ
できるはずだ。
またuseしてるモジュールがないときは、エラーメッセージは
Can't locate ナントカ.pm in @INC (@INC contains: (中略)) at ほげほげ line XX.
BEGIN failed--compilation aborted at ほげほげ line XX.
って2行でる。勝手に1行目削られるとナントカ.pmがないっていう
いちばん肝心な情報がわからなくなるわけだ。だからちゃんとした
アドバイスを受けたければエラーメッセージをそのまま貼れって
いわれるのよ。
次になんか質問するときは気をつけよう。
0221nobodyさん
04/10/20 14:42:43ID:???ファイル名にマルチバイト文字が使われているファイルがサーバーにあるとして、
そのファイルに直接アクセスしようとしても404になり、
マルチバイト文字の部分だけをURLエンコードすると正常にアクセスできます。
検索CGIを作っていまして、ファイル名にマルチバイト文字がある場合、
URLエンコードを行なってから検索結果画面を出そうと思っています。
例えば、このCGIからマルチバイト文字をファイル名に使ったファイルへのパスが
../data/俺俺.txt
だとします。
この場合、../の部分を絶対パスに置き換えてから検索結果に出力しているのですが、
http://www.domain.com/data/俺俺.txt
の「俺俺」の部分だけをURLエンコードする方法をご存知の方はいないでしょうか。
Perlメモにて全角文字の有無を検出する方法はわかったのですが、
全角文字の部分だけを変換して変数に保存したいのです。
0222nobodyさん
04/10/20 14:48:18ID:???$path =~ s/(全角文字列にマッチする正規表現)/URLエンコードする関数($1)/ge;
とかでいいんじゃないの?
0223nobodyさん
04/10/20 15:03:45ID:???0224221
04/10/20 15:18:11ID:???出力されるページ及びスクリプト自体はSJISなので、
EUC変換を行なってから下記のコードを追加しました。
# Perlメモの正規表現より「ASCII以外」の文字列がある場合
if ($path =~ /[\x8E\xA1-\xFE]/) {
# 「ASCII以外」の文字列をエンコードする
$path =~ s/([\x8E\xA1-\xFE])/'%'.unpack("H2", $1)/eg;
}
とりあえずはこの方法で解決できそうです。
即レス感謝です。
0226221
04/10/20 16:05:39ID:???ちなみにローカルでのテスト環境は、「Win2000Pro ActivePerl5.6.1 AN HTTP Daemon 1.42k」です。
HTMLの読み物として「リンクの方法.txt」というファイルが実際にありまして、
とりあえずそれを検索する事でテストしています。
「リンクの方法」はSJISですと「%83%8A%83%93%83%4E%82%CC%95%FB%96%40」、
EUCですと「%A5%EA%A5%F3%A5%AF%A4%CE%CA%FD%CB%A1」となるようです。
一部省略してますが、該当部分のソースを下に書かせていただきます。
$temp_euc = $temp; # $tempはsjisで、ファイル名だけが入ってます
&jcode::convert (\$temp_euc, "euc"); # $tempをEUCにした$temp_eucを用意
if ($temp_euc =~ /[\x8E\xA1-\xFE]/) { # Perlメモの正規表現より「ASCII以外」の文字列がある場合
$temp_euc =~ s/([\x8E\xA1-\xFE])/'%'.unpack("H2", $1)/eg;
}
print <<"HTML";
<A href="$absolute_dir\/$temp_euc">$temp</A> # 絶対パスとファイル名を結合したパスへとリンク
HTML
この方法ですと、>>224氏が言ったように、
<A href="http://www.domail.com/%A5%EA%A5%F3%A5%AF%A4%CE%CA%FD%CB%A1.txt">リンクの方法.txt</A>
となり、<A>タグ内のリンク先のファイル名がEUCとなって、ファイルシステム上のファイル名の関係で使えませんでした。
もう少しやり方を模索してみます。
0227221
04/10/20 16:10:55ID:???要するに、マルチバイト文字だけをURLエンコードしたいが、
マルチバイト文字を正確に検出するにはEUC形式である必要がある。
しかし、そのままEUCをURLエンコードしてもファイルシステムの都合上使えないため、
マルチバイト文字に該当する部分だけをSJISでURLエンコードができれば、ということです。
0229460
04/10/20 17:03:41ID:???if ( A ){ if ( B ){ 〜 }}か
if ( A , B ){ 〜 }
で良いかな?
0230nobodyさん
04/10/20 17:08:37ID:???0231nobodyさん
04/10/20 17:08:54ID:???0233231
04/10/20 17:09:17ID:???0236221
04/10/20 17:24:04ID:???申し訳ないですが、もう少し方法を具体的に教えていただけないでしょうか。
「EUCで取り出した」とはどの部分を指すのでしょうか。
$temp_euc =~ s/([\x8E\xA1-\xFE])/'%'.unpack("H2", $1)/eg;
のように、一括で変換を行なうわけではないということですか?
0237nobodyさん
04/10/20 17:28:45ID:???その例でいくと
unpack("H2",$1)
のところを
unpack("H2",eucをsjisに変換する関数($1))
にすればいいってことでしょ。
0241nobodyさん
04/10/20 22:16:04ID:???, -,:' / ̄) i{'r‐-、 `ヽ、
. _...,,o‐y ,:'- '⌒ ⌒ヽ. `ヽ' ,
(o( ,' / / 、 `ヾ. ヾ,
,:'´//7,' ,' .,' ,:' ! } i !', ':, ':, ゙:,
,' / ,' {l. ! {/ ,イ / }| !|', !. ', ', ゙,
ハ〃 ! !| | | ∠/ ,:'-ノ} /リ l ,ム. ! } |!
ハヽ、ゝ!| l | ,:',;='ィ'、'´ ,'.ノ ノ.,;lノ=、l .,' ,' ,' ノ
{ l l ', |'ヲi(_ノ.} ´ i(ノ.}゙!ノ,:',:''´
', h. ', ',゙、 ':゙゙_.ノ. ':゙_ノ〃ン
':, { ',', ':,':, 丶 ,' l .}
ヾ ':,':, ':ヾ、._ 「´/ ,' | .,' / ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄ ̄
`ヾ-、`ヽ_ `´ _,.ィリ.ノ ,' < なんとなかるよ、絶対大丈夫だよ!
リ';',ヾ| ` ‐┬ ´ _ノノ,'/ \______________
ヾ,、-- 、 _ | ´ノ'
f ヾ、..___ ヽ、 ー‐''
/_......_ \
0242nobodyさん
04/10/20 22:31:34ID:???0243nobodyさん
04/10/20 22:35:28ID:xGLMj0YBこのコードの意味がさっぱり分からんのでオシエテクリソ-
0244nobodyさん
04/10/20 22:56:55ID:???$abc, $def の2人が「俺の物だ」って奪うんだよ。
でも不思議なことに奪われた袋の中身はなくなっていなーい。
0245nobodyさん
04/10/20 23:02:27ID:???0246nobodyさん
04/10/20 23:14:24ID:xGLMj0YB@_は変数ではないですよね?
もう少しヒントクリソー
0247nobodyさん
04/10/20 23:26:27ID:???0248nobodyさん
04/10/21 01:10:59ID:???$str =~ s/([\x81-\x9f\xe0-\xfc])([\x40-\x7e\x80-\xfc])/sprintf("%%%02X%%%02X",ord($1),ord($2))/eg;
っと、半角カナ用にもう一押し必要か。残念!
\xa0-\xdf斬り。
0249nobodyさん
04/10/21 01:31:19ID:???ASCII文字って厳密にはどこまでを指してんだ?
半角英数字記号をASCIIってとらえるんなら、
0250nobodyさん
04/10/21 02:46:20ID:???0251201
04/10/21 05:43:48ID:???LAN側からのみルーターにプライベートアドレスでtelnetでアクセス
で情報を得る。
0252nobodyさん
04/10/21 10:50:09ID:???my ($abc, $def) = @_;
print ($abc, $def);
print \n;
print @_;
する
0253221
04/10/21 11:33:49ID:???$temp_euc = $temp; # $tempはsjisで、ファイル名だけが入ってます
&jcode::convert (\$temp_euc, "euc"); # $tempをEUCにした$temp_eucを用意
if ($temp_euc =~ /[\x8E\xA1-\xFE]/) { # Perlメモの正規表現より「ASCII以外」の文字列がある場合
$temp_euc =~ s/([\x8E\xA1-\xFE])/'%'.unpack("H2", &euc2sjis ($1))/eg; # ここを変更
}
print <<"HTML";
<A href="$absolute_dir\/$temp_euc">$temp</A> # 絶対パスとファイル名を結合したパスへとリンク
HTML
sub euc2sjis { # 追加したサブルーチン
my $str = $_[0];
&jcode::convert (\$str, "sjis", "euc");
return $str;
}
>unpack("H2",eucをsjisに変換する関数($1))
と言って下さったように変えてみたのですが、HTML部に表示されるエンコードされたURLは変わらずEUCのままでした。
追加したサブルーチンが動いていないのかとも思って確認しましたが、
単体で動かして確認したところ、sub euc2sjisは正常に動いているようです。
他の方が提示してくださった方法も見てみます。
0255nobodyさん
04/10/21 12:09:34ID:???なんか、そこはかと遠回りしている気がするよ。\Wをエンコードするだけじゃ動作しなかったっけ?別に正確なURLエンコードを目指さなくても動作すればそれでいいのでは?
0256nobodyさん
04/10/21 12:24:56ID:???諦めるのかw
0257nobodyさん
04/10/21 12:30:19ID:a34sr5QLa0001
a0002
a0003
という風に増加する変数を作りたいのですがどうすればいいでしょうか?
参考になるサイトなんかあったら教えてください。
宜しくお願いします
0259nobodyさん
04/10/21 12:39:13ID:???0260nobodyさん
04/10/21 12:55:04ID:???レスありがとうございます。素朴な疑問ですが、
アルファベット文字含んでても、++で問題なく a002 になるんでしょうか?
>>259
調べてみます。ありがとうgざいます。
■ このスレッドは過去ログ倉庫に格納されています