5丁目通信(仮称)

とある5丁目で活動する還暦を過ぎたWebプログラマーの覚え書きです。それとかかってくる迷惑電話や、家業のアパート経営について。

PHPのfgetcsv()は使えない?という話し


PHPの関数で用意されているfgetcsv()は、CSVファイルを一行読み込んで、各項目を配列で返してくれます。こんな感じ。

$handle = @fopen("testtest.csv", "r");
$buffer = fgetcsv($handle, 4096);

ただし、CSVファイルに2バイトのデータが含まれていたら、うまく切り分けてくれない。PHPの内部コードはUTF-8で、CSVファイルがシフトJISなら、変なところで切ってくれる。

仕方ないので、手っ取り早く

$handle = @fopen("testtest.csv", "r");
$buffer = split(",", fgets($handle, 4096));

のように変更してあげる。CSVファイルはこちらでプログラムで生成されているので、途中にコンマが紛れてこないだろうということで、とりあえずOKとしておきます。なんだが美しくないなあー。これだと完全なCSVファイルの処理をしていないので、また後で考えなければいけないか・・・。

著:山田祥寛
¥3,366 (2024/11/21 16:43時点 | Amazon調べ)
著:松浦 健一郎, 著:司 ゆき
¥2,574 (2024/11/21 16:43時点 | Amazon調べ)
著:谷藤賢一, 著:徳丸浩
¥2,750 (2024/11/21 16:43時点 | Amazon調べ)

“PHPのfgetcsv()は使えない?という話し” への2件のフィードバック

  1. anishioのアバター

    fgetcsv()はそもそもPHP5で文字化けの不具合があるので、使えない可能性大ですよね。

    個人的にはCSVやTABテキストファイルを読むのであれば、explode()を好んで使っています。

  2. andoのアバター
    ando

    コメントありがとうございます。

    explode()というのもありですね。PHPのマニュアルを見るとsplit()との違いが、初めてわかりました。情けない・・・。

    今は単純にコンマ区切りでいいのですが、完璧にCSVファイルを読み込め、なんて案件が来たら面倒なことになりますね。