【PHP】下らねぇ質問はID出して書き込みやがれ 86
953 :
nobodyさん:2009/08/28(金) 14:40:02 ID:IryiXPVo
TREEFILEはスレッド順に並んだログ番号ファイルで
1,3,4\n
だとLOGFILEの記事番号1番がスレッド記事、3&4番がレス記事になります。
記事内のコメントにキーワード文字が含まれてる場合、
そのスレッドツリー丸ごと1行分を$hitthreadlineに
該当したスレッド分格納したいのですが
どうも上記プログラムを実行すると$hitthreadlineに
何も挿入されておりません。
ログの方にはキーワードを含まれた分があるのですが・・・・
何かおかしいところあるでしょうか?
954 :
nobodyさん:2009/08/28(金) 14:41:47 ID:IryiXPVo
明らかにおかしかった部分は書き直しましたがまだ先程と動作変わりません。
文章は
>>953です。
$keyword = "ああああ";
$treelog = file(TREEFILE);
$log = file(LOGFILE);
$threadcount = count($treelog);//スレッド数をカウント
for($i=0; $i<$threadcount; $i++){
$writing = explode(",", $treelog[$i]);
$writingcount = count($writing);
for($j=0; $j<$writingcount; $j++){
$rrrr = $writing[$j];
list($no,$now,$name,$email,$sub,$model,$com,$host,$pwd,$ext,$w,$h,$time,$chk) = explode(",", $log[$rrrr]);
if(mb_ereg_match($keyword,$com)){
$hit = TRUE;
}
}
if($hit == TRUE){
$hitthreadline .= "$i\n";
$hit = FALSE;
}
}
echo "$hitthreadline";
1行ごとに値をチェックしてみ
>>954 そんなコードじゃコピペしてすぐ試せないだろクズが!
define使わないで書けやできそこない
957 :
nobodyさん:2009/08/28(金) 14:50:40 ID:IryiXPVo
>>955 やってみます、ありがとうございます。
>>956 昨日と同じ方ぽいのですが
外部ロダにあげるなやらちょっと無茶すぎやしませんか。
昨日言われたとおりにここにわざわざ書き込んだのに。
結局ログ自分で用意しないといけないから
defineも糞もないと思うんですが。
◆質問後の注意
・2回目以降は最初に質問した際のレス番号を入れて、偽者防止に必ずIDを表示させること。
・解決しなくても回答をもらった場合はお礼を言うこと。
(荒らし、煽りは除く。煽られたときも、無闇に反論せずスルーすること。)
ヌルーしとけー
>>957 $treelog = file(TREEFILE);
$log = file(LOGFILE);
$treelog = file(TREEFILE);
$log = file(LOGFILE);
$treelog = file(TREEFILE);
$log = file(LOGFILE);
$treelog = file(TREEFILE);
$log = file(LOGFILE);
$treelog = file(TREEFILE);
$log = file(LOGFILE);
$treelog = file(TREEFILE);
$log = file(LOGFILE);
$treelog = file(TREEFILE);
$log = file(LOGFILE);
960 :
nobodyさん:2009/08/28(金) 15:04:57 ID:IryiXPVo
$treelog = file("./treefile.txt");
$log = file("./logfile.log");
みたいに書きなおせ氏ね
・ 質問者として、態度をわきまえること。
>>957 >結局ログ自分で用意しないといけないからdefineも糞もないと思うんですが。
日本語でおk
お前が用意しろよ
コピペして動かないだろバカなの?
・ 回答者として、態度をわきまえること。
残念だけどここは抽象的なことを抽象的に返す場所で
具体的な答えを求めてもかえって来ないよ
わからんから
ID:IryiXPVoスルー推奨
>>954 本題と関係ないんだけど、
$log[$rrrr]ってことはログ番号=ログファイル内での行番号ってこと?
ログファイルに(バグとか手修正で)意図しない行が追加/削除される
だけで破綻するんじゃないか?
DB使えば?
971 :
954:2009/08/28(金) 15:54:25 ID:IryiXPVo
データベース覚えるとまた時間かかるので
とりあえず基礎技術だけ覚えるために
ログからの書き出しで行こうと思いました。
ファイル読む過程中ロックかけても駄目でしょうか?
972 :
954:2009/08/28(金) 15:56:35 ID:IryiXPVo
>>970 ああああを含む書き込み番号を後で出力するために
変数に格納したいのです。
973 :
954:2009/08/28(金) 16:01:07 ID:IryiXPVo
あげたphpの8行目の書き方間違えてるようですね・・・・
どうなおしたらいいんだろう。
8行目間違えてるってなんで?
>>972 <?php
$keyword = "ああああ";
$log = file("img.log");
$hit = array();
foreach ($log as $value) {
$tmp = explode(",", $value);
if (preg_match("/^".$keyword."$/", $tmp[6])) {
$hit[] = $tmp[0];
}
}
var_dump($hit);
?>
こういうこと?
976 :
954:2009/08/28(金) 16:18:52 ID:IryiXPVo
>>974 1行ずつ出力したら思った行動と違う結果が出てきたんです。
ちょっとその部分見つけた後いじりすぎてどこが間違ってたか
具体的に説明できないのですが。
>>975 記事部分だとそうなのですが
欲しいのはツリー部分の該当列番号なんです。
その9番記事が格納されている
ツリーログの0含めて3番目が出力されるのが正解だと思います。
説明足らずですいません。
>>976 <?
header("content-type:text/plain;charset=euc-jp"); $keyword = "ああああ";
$treelog = file("./tree.log");
foreach(file("./img.log") as $line){
$tmp = explode(",", $line);
$log[$tmp[0]] = $tmp;
}
$threadcount = count($treelog);//スレッド数をカウント
for($i=0; $i<$threadcount; $i++){
$writing = explode(",", $treelog[$i]);
$writingcount = count($writing);
for($j=0; $j<$writingcount; $j++){
$rrrr = trim($writing[$j]);
if(mb_ereg_match($keyword,$log[$rrrr][6])){
$hit = TRUE;
}
}
if($hit == TRUE){
$hitthreadline .= $i;
$hit = FALSE;
}
}
echo "$hitthreadline";
?>
こんな感じか?
できるだけそのまま書いてみた。
978 :
977:2009/08/28(金) 16:22:32 ID:???
>>977 header("content-type:text/plain;charset=euc-jp");
は無視してちょ...。
979 :
954:2009/08/28(金) 16:25:49 ID:IryiXPVo
>>977 そうです、その動作です。
間違ってると思ってた8行目の動作はあっておりました、すいませんでした。
ちょっと回答ログ見直してどこがおかしかったか見直してみます。
980 :
954:2009/08/28(金) 16:28:02 ID:IryiXPVo
肝心のお礼忘れておりました、
本当にありがとうございました。
これで前進できそうです。
981 :
954:2009/08/28(金) 16:48:59 ID:IryiXPVo
申し訳ありませんが最後にもう一つ教えて下さい。
$rrrr = trim($writing[$j]);
ここで空白が入ってうまくいってなかったようなのですが
$writing = explode(",", $treelog[$i]);//1スレッド分の記事番号を$writingに格納
ここで配列に格納したはずなのになぜ空白が入る余地があるのでしょうか?
982 :
954:2009/08/28(金) 16:50:11 ID:IryiXPVo
$rrrr = $writing[$j];修正前
$rrrr = trim($writing[$j]);修正していただいた後
補足を
>>982 空白?については判らないけど、
trimなしでうまくいかなかったのは、fileで読み込むと改行コードも入るからだよ。
たとえば、1行目の「18」は実際には「18<改行コード>」になっていた。
$log[$rrrr]は、$log[18]ではなく$log[18<改行コード>]を取得しようとしたが、そんな要素はないので。
それと$logのキーの問題の2箇所がまずかった。
__ _____ r―‐┐┌――┐ _
/ ∠___, |______ | /_/7 / 7 厂| | く\ ||
l ___ | | | _/ 〈_ L/ [_| ヽ」┌─┘└─┐
| |___| | ____| | | 口 口 | /Z_冂_ 〈\.└─┐┌┐│
l ___ | | | | 口 口 l〈_,r┐┌┘ \/__| L_」 |_
| |___| | | | ̄ ̄ ̄ ̄ |┌ー┐|┌ ┘└┐ |__ ___|
l ___ | | | || ||└ ┐┌┘ / 〉 / \
| |___| | | ヽ____/| || || | | / / //\ \__
l______| ヽ_____ノ |.」 [__| |_.」 く_/ く_/ \_ノ
_ _ _ _
| | __| |__ | | __| |__
| | |__ __| | | |__ __|
| | __| |__ | | | | __
| | |__ __| | | | | └─‐┘
| | _ ___| |_ | | _ / /
l ヽ__/ | /┌┐ _ \ l ヽ__/ | / / |ヽ___
\__/ ヽ、二__ノ ヽ/ \__/ ∠_/ `ー――'
俺がスレ建てるから待ってろ
>>986 コピペしたままはろうとすると専ブラじゃ制限にかかるようにみえるが
きっちり32ラインになるようにテンプレ作られてるんだよ
>過去スレ、関連スレ、FAQなどは
>>2-10辺り
これを抜かすのは関心しないな
どうせ削るなら誰も使ってない質問用テンプレ消せばよかったのに
989 :
954:2009/08/28(金) 17:15:34 ID:IryiXPVo
ご説明ありがとうございます、
お礼にスレ立てしようとしたんですがp2だと
ちょっとスレ立て項目見当たらないので
少しお待ちください、検索続けてみます。
991 :
954:2009/08/28(金) 17:16:54 ID:IryiXPVo
ああ、立ってた。
>過去スレ、関連スレ、FAQなどは
>>2-10辺り
別にこんなの見ないしどうでもいいに一票入れとく
姉妹スレDAT落ちじゃん
えー・・・
過去・関連スレはともかく
関連リンクやFAQは重要じゃないか
その一文自体は要らないだろ
いる
>質問者はまず
>>1を良く読むこと(必須!)
>次スレは
>>980が立てる。10分以内に立たない場合、宣言してから立てたい人が立てること。
だけだと
>>1にしか目がいかない
普通、質問する前に過去スレ過去ログを調べるのが当たり前だから不要
| 1.文字コードは何を使えばいいの?
| →1.UTF-8 2.EUC-JP のどちらか。迷うようなやつはShift_JISは使っちゃダメ。
今ならもう UTF-8 のみでいいのでは
>>998 そりゃお前の普通だろw
1000GET
1001 :
1001:
このスレッドは1000を超えました。
もう書けないので、新しいスレッドを立ててくださいです。。。