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

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

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

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

Q&A

解決済

1回答

2561閲覧

phpのzip関数でcsvファイルを正しく読込みたい

double16k

総合スコア16

PHP

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

0グッド

0クリップ

投稿2017/07/23 06:21

以前も質問させていただいたのですが、詰まった箇所があるのでお願いいたします。

//ファイルパス $path = $tmp_name; //zipファイルをオープン $zip = zip_open($path); if( $zip ){ while( $entry = zip_read($zip) ) { $csv_file = basename(zip_entry_name($entry)); //zip内のファイルをオープン zip_entry_open($zip, $entry, "r"); //オープンしたファイルを読み込む $entry_content = zip_entry_read($entry, zip_entry_filesize($entry)); $entry_content = mb_convert_encoding($entry_content, "UTF-8", "SJIS-win"); zip_entry_close($entry); } } zip_close($zip);

以前と同じコードですが、zipファイルの中のcsvファイルを読み込むと1レコードであれば問題なく読み込めるのですが
例:1レコード目(A,B,C) 2レコード目(D,E,F)
複数のレコードがあるcsvを読み込むと$entry_contentの中身が
例:(A,B,C D,E,F)
となり以前教えていただいた $entry_content = str_getcsv($entry_content, ",", '"');関数だと
array[0] = A,
array[1] = B,
array[2] = C D,
array[3] = E,
上記のようにarray[2]にC,Dが入っている状態です。

zipを展開してcsvを保存せずに複数レコード読み込みたいのですが、zipを展開してcsvを保存してからcsv関数を使って読み込まないといけないでしょうか。

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

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

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

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

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

guest

回答1

0

ベストアンサー

str_getcsvでは改行がデリミタと認識されない様ですので、fgetcsvにてメモリファイルから再読み込みで処理を行ってみました。

php

1$path = $tmp_name; 2 3//zipファイルをオープン 4$zip = zip_open($path); 5 6if( $zip ){ 7 8 while( $entry = zip_read($zip) ) { 9 10 $csv_file = basename(zip_entry_name($entry)); 11 echo "file:".$csv_file."\n"; 12 13 //zip内のファイルをオープン 14 zip_entry_open($zip, $entry, "r"); 15 16 //メモリに書き込み 17 $fp = fopen('php://memory', 'r+'); 18 fwrite($fp, zip_entry_read($entry,zip_entry_filesize($entry))); 19 //先頭に戻る 20 rewind($fp); 21 22 $entry_content=array(); 23 while ($rows = fgetcsv($fp)) { 24 $entry_content = array_merge($entry_content, $rows); 25 } 26 // メモリファイルクローズする 27 fclose($fp); 28 29 mb_convert_variables('UTF-8' , 'SJIS' , $entry_content ); 30 print_r($entry_content); 31 32 zip_entry_close($entry); 33 } 34} 35zip_close($zip);

投稿2017/07/23 09:28

A.Ichi

総合スコア4070

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

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

double16k

2017/07/23 09:45

A.Ichi 様 ご回答いただきまして、誠にありがとうございます。 csvの処理に大変困っておりました、ご提示されたコード大変勉強になります。 zip解凍からcsvをダウンロードし、そこから処理しようとしていました、こちらで進めていこうと思います。 ありがとうございました。m(__)m
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問