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

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

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

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

プログラミング言語

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

Q&A

解決済

1回答

610閲覧

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

maibear3

総合スコア5

PHP

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

プログラミング言語

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

1グッド

1クリップ

投稿2022/11/29 09:28

編集2022/12/01 10:14
コード ```### 使用するファイル 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👍を押しています

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yuma.inaura

2022/11/29 10:32

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

回答1

0

ベストアンサー

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

総合スコア114585

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

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); の使い方でそんな使い方あるんだなと驚きました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問