
いつも参考にさせていただいております。今回はじめての質問になりますが、よろしくお願いします。
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ランキング
-
アンケートフォームの作り方
-
PHPでMP3サーバを作るには
-
氏名をあいうえお順に並べて行...
-
テキストボックにカーソルを合...
-
PHPによるCSVファイルの指定列...
-
PHPでユーザー情報を入力して簡...
-
ラジオボタンの値によって他の...
-
チェックボックス 複数選択
-
2つのsubmitボタンがあるときに
-
HTMLで前の画面に戻る時、入力...
-
チェックボックス、セレクトメ...
-
PHP 配列の受け渡し
-
<input type='checkbox'>要素で...
-
POSTをボタンではなくリンク等...
-
テキストフォームからの受け取り
-
複数行のデータ一括更新に関して
-
初心者の質問「htmlspecialchars」
-
フォームから値を受け取る方法...
-
フォームから受け取る値について
-
フォーム INPUTの文字化け対策...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
検索時の選択内容を保持する方法
-
HTMLで前の画面に戻る時、入力...
-
同じページでフォームデータを...
-
PHPで、ボタンを押すと同じペー...
-
フォームボタンを押すたびに数...
-
フォームへの前回入力値をクリ...
-
DBの値をチェックボックスに反...
-
チェックボックスによる検索
-
HTMLフォームで複数選択のチェ...
-
フォームでのリセットを使う方法
-
エラーを元の画面に表示させるには
-
PHP ボタンが押されたら処理を...
-
チェックボックスの必須項目指定
-
【PHPチェック】ラジオボタンが...
-
POSTやGETの変数をフォーム無し...
-
PHPでクリックするたびに変数を...
-
入力した部分を表示させたまま...
-
ラジオボタンをsessionで使いたい
-
POSTデータのNAME属性をVALUEに...
-
アップロードの際にファイルパス
おすすめ情報