質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
86.12%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。

解決済

php 完全一致 csvファイル文字列

maibear3
maibear3

総合スコア4

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。

1回答

1グッド

1クリップ

233閲覧

投稿2022/11/29 09:28

編集2022/11/29 09:45
コード ```### 使用するファイル test1.csv↓ name りんご みかん めろん test2.csv↓ name,price りんご,100 かき,200 みかん,300 みかん,150 ### 実現したいこと phpで2つのcsvファイルに書いてある文字列が完全一致しているかを判断できるコードを作成したいです。 test1.csvの果物の名前がtest2.csvに完全一致であればそのpriceを抽出してtest3.csvを作成したです。 みかんのように複数ある場合も出力できるようにしたいです。 test3.csv↓ name,price りんご,100 みかん,300 みかん,150 ### 試したこと php コード <?php $search_word = 'りんご'; if (($handle = fopen("test2.csv", "r")) !== FALSE) { while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) { if(count(preg_grep('/'.$search_word.'/', $data)) > 0){ var_dump($data); } } fclose($handle); } で行った結果あいまい検索になってしまい、またヒットした果物の価格まで表示できませんでした。
maibear3👍を押しています

以下のような質問にはグッドを送りましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

グッドが多くついた質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

下記のような質問は推奨されていません。

  • 間違っている
  • 質問になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

適切な質問に修正を依頼しましょう。

2022/11/29 09:33依頼された後にこの質問は修正されています

こちらの質問が他のユーザーから「やってほしいことだけを記載した丸投げの質問」という指摘を受けました。

yuma.inaura

2022/11/29 10:32

コードブロックと文章を整えてみましょう

回答1

1

ベストアンサー

PHP

1$fp=fopen('test1.csv',"r"); 2$data=preg_split("/[\n\r]+/",fread($fp,1024)); 3fclose($fp); 4$fp=fopen('test2.csv',"r"); 5$csv=[]; 6while(($row=fgetcsv($fp))!==false){ 7 if(in_array($row[0],$data)) $csv[]=$row; 8} 9fclose($fp); 10print_r($csv); // これを追記すれば状況わかるはず 11$fp=fopen('test3.csv',"w"); 12foreach($csv as $row) { 13 fputcsv($fp,$row); 14} 15fclose($fp);

追加仕様対応

PHP

1<?PHP 2$fp=fopen('test1.csv',"r"); 3while(($row=fgetcsv($fp))!==false){ 4 $data[$row[0]]=$row[1]; 5} 6fclose($fp); 7array_shift($data); 8$fp=fopen('test2.csv',"r"); 9$csv=[]; 10while(($row=fgetcsv($fp))!==false){ 11 if(isset($data[$row[0]])) $csv[]=array_merge($row,[$data[$row[0]]]); 12} 13fclose($fp); 14array_unshift($csv,["name","price","id"]); 15print_r($csv); 16$fp=fopen('test3.csv',"w"); 17foreach($csv as $row) { 18 fputcsv($fp,$row); 19} 20fclose($fp);

投稿2022/11/30 01:53

編集2022/11/30 06:31
yambejp

総合スコア108937

spoofy_dragon👍を押しています

良いと思った回答にはグッドを送りましょう。
グッドが多くついた回答ほどページの上位に表示されるので、他の人が素晴らしい回答を見つけやすくなります。

下記のような回答は推奨されていません。

  • 間違っている回答
  • 質問の回答になっていない投稿
  • スパムや攻撃的な表現を用いた投稿

このような回答には修正を依頼しましょう。

回答へのコメント

maibear3

2022/11/30 05:02

ありがとうございます。 実行結果としましては、test3.csvには何も出力されませんでした。 プログラムの流れとして、test1.csvの中身を配列として test2.csvの中身と一行ずつ比較 ヒットしたものだけをtest3.csvに記載 という流れでしょうか?
yambejp

2022/11/30 05:49

test3.csvは書き込み可能状態でしょうか? いちおうcsvデータの状況を回答に追記してあります
maibear3

2022/11/30 05:55

先頭に<?php をつけ忘れたせいでcsvに書き込みできてませんでした。 <?php を記載したところ test3.csvに出力することができました。ありがとうございます。 test1.csv↓ name,id りんご,1 みかん,2 めろん,3 test2.csv↓ name,price りんご,100 かき,200 みかん,300 みかん,150 test3.csv↓ name,price,id りんご,100,1 みかん,300,2 みかん,150,2 というものを作るとなるとどのように変化しますでしょうか? while(($row=fgetcsv($fp))!==false){ if(in_array($row[0],$data)) $csv[]=$row; } の部分があまり理解できず改善策が思い浮かばない状態です。
yambejp

2022/11/30 06:31 編集

質問が変わってきてますね・・・ 追記しました。
maibear3

2022/12/01 01:14

ご回答ありがとうございます。 関数の引数等調べながら理解することができました。 array_shift($data); の使い方でそんな使い方あるんだなと驚きました。 ありがとうございました。

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
86.12%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

プログラミング言語

プログラミング言語はパソコン上で実行することができるソースコードを記述する為に扱う言語の総称です。