いつも参考にさせていただいております。今回はじめての質問になりますが、よろしくお願いします。
PHPによるCSVファイル内の指定列内を検索する方法について困っております。似たような質問(http://oshiete1.goo.ne.jp/qa3570985.html)を参照しましたが、どうにもわからずほとほと困っている状態です。
とりあえず他サイトを参考にして検索フォームを下記のように作成しました。(ラジオボタンの送信内容は便宜上変更しました)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=SHIFT-JIS">
<title></title>
</head>
<body>
<form action="search_4.php" method="POST">
<INPUT type="radio" name="touroku_type" value="りんご">りんご
<INPUT type="radio" name="touroku_type" value="なし">なし
<INPUT type="radio" name="touroku_type" value="ぶどう">ぶどう
<INPUT type="radio" name="touroku_type" value="メロン">メロン
<INPUT type="radio" name="touroku_type" value="スイカ">スイカ<BR>
<input type="submit" name="submit" value="検索">
</form>
<!--ここから検索結果-->
<ul>
<?php
if($_POST["touroku_type"]!=""){
$KeyWord=$_POST["touroku_type"];
$KeyWord=htmlspecialchars($KeyWord);
$Data=file("system.csv");
for($i=0;$i<sizeof($Data);$i++){
$lines=strip_tags($Data[$i]);
if(mb_eregi($KeyWord,$lines)){
$line=explode(",",$Data[$i]);
?>
<li><?=$line[3]?> → <a href="item.php?id=<?=$line[0]?>">詳細を見る</a></li>
<?php
}
}
}
?>
</ul>
</body>
</html>
CSVファイルの登録情報は
1,りんご,あり
2,なし,あり
3,ぶどう,なし
4,メロン,なし
5,スイカ,なし
とします。
この場合、”りんご”や”スイカ”など他で入力されていない情報で検索した場合きちんと出ますが、”なし”で検索すると2から5の情報が出てしまい検索として役に立たない状態です。
ここで質問なのですが、PHP上で指定列のみを検索する場合(上記の場合、配列の2つ目のみを検索対象とする)、上記プログラムのどこを変更すべきなのかご教授いただけますでしょうか?
よろしくお願いします。
No.1ベストアンサー
- 回答日時:
こんにちは。
はじめまして。
ソースを拝見しました。
「なし」で検索をするとCSVの3列目の「あり・なし」も
引っかかってしまってますね。
ということは2列目のみ検索させなければならないので、
先に explode で各列に分割し、2列目のみを検索対象にします。
こんな感じです。
<!--ここから検索結果-->
<ul>
<?php
if($_POST["touroku_type"]!=""){
$KeyWord=$_POST["touroku_type"];
$KeyWord=htmlspecialchars($KeyWord);
$Data=file("system.csv");
print_a($Data);
for($i=0;$i<sizeof($Data);$i++){
$lines=strip_tags($Data[$i]);
$line=explode(",",$Data[$i]);
if(mb_eregi($KeyWord,$line[1])){
?>
<li><?=$line[1]?> → <a href="item.php?id=<?=$line[0]?>">詳細を見る</a></li>
<?php
}
}
}
?>
</ul>
いかがでしょうか。
explode様
回答ありがとうございました。
指示通りに書き換えて実行したところ、見事指定列のみを検索対象とすることができるようになりました。ここで2週間ほど躓いていたので感動の極みです。
しかし、少し変えただけで動くようになるなんて勉強不足としか言いようがないですね。お恥ずかしい。CSVに関する参考書自体なかなか本屋に置いていない事が多いので情報源がネットに偏りすぎて応用が利かないのはまずいですね。もっと勉強します。
アドバイスありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP PHPでユーザー情報を入力して簡易ログイン機能をつくってみたのですが 1 2023/05/29 08:51
- PHP 入力した部分を表示させたまま(保持)するにはどうすれば良いでしょうか? 1 2023/01/25 11:14
- PHP PHPでCookieを使った訪問回数について 1 2023/05/28 14:10
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- PHP PHPのエラーの解消法について教えて下さい。 1 2023/02/06 10:48
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
- PHP PHPで画像の渡しが上手く行きません。 1 2023/02/02 09:39
- HTML・CSS 私の能力からして間違っていないような気がします。 4 2022/09/30 13:24
- HTML・CSS ただいま勉強始めたての初心者です。フォームを縦並べにしたいです。 2 2022/11/20 17:18
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
<input type="hidden" >で配列...
-
HTMLで前の画面に戻る時、入力...
-
ラジオボタンのチェックを判定...
-
テキストボックスに初期値を入れる
-
PHPでMP3サーバを作るには
-
検索時の選択内容を保持する方法
-
PHPを勉強中の専門学生です。 ...
-
ラジオボタンの値によって他の...
-
PHP ボタンが押されたら処理を...
-
1つのphpファイルで、入力フォ...
-
PHPのページ間による配列の受け...
-
テキストボックにカーソルを合...
-
php + javascriptで値の保持
-
PHP DBの登録情報をラジオボタ...
-
テキストボックスとsubmitボタ...
-
チェックボックスのvalueを連結...
-
PHPのmysqlに格納したデータの...
-
フォーム INPUTの文字化け対策...
-
フォームボタンを押すたびに数...
-
php、HTML5に詳しいかた。H...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
HTMLで前の画面に戻る時、入力...
-
<input type="hidden" >で配列...
-
PHP ボタンが押されたら処理を...
-
検索時の選択内容を保持する方法
-
DBの値をチェックボックスに反...
-
ラジオボタンをsessionで使いたい
-
パラメーターを隠す
-
PHPで画像の渡しが上手く行きま...
-
フォームへの前回入力値をクリ...
-
フォームボタンを押すたびに数...
-
フォームでのリセットを使う方法
-
syntax error, unexpected '}' ...
-
PHPの関数実行
-
phpで分からないエラーが出てし...
-
テキストボックスに初期値を入れる
-
入力した部分を表示させたまま...
-
入力フォーム→確認画面→送信画...
-
Javascript→PHPに...
-
画面が更新されてもチェックボ...
-
配列をhiddenで
おすすめ情報