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

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

ただいまの
回答率

89.11%

SplFileObjectで改行を含むcsvファイルを読み込むと最初の改行が1つなくなる?

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 5,849

msx2

score 164

PHPを使ったプログラムでCSVファイルをアップロードしてテーブルに保存する処理を作りました。

テストをして気づいたのですが、どうやらCSVファイルに改行が含まれていると最初の1つがなくなるみたいです。

自分なりに試してみた結果、ファイルは正しく読めていてそのままテキストファイルとして保存すると改行は残っていました。また文字コードは変換してもしなくても結果は変わらず、改行コードはCR+LFでもLFでも同じ結果です。

SplFileObjectがcsvを読み込むと発生するみたいです。

ちなみにfgetcsvで読み込むと改行は消えず期待通りのデータが取得できます。

改行の含まれるcsvファイルはcsvじゃない!というご意見は承知していますが業務上必要なのでそうも言ってられません。

SplFileObjectのREAD_CSVのバグでしょうか?
できればSplFileObjectを使いたいと思っているので回避方法があれば教えていただきたいです。

※今の環境はPHPやサーバーの設定は変更できない状況です・・

$filename = $getfile[0]['saved_to'] . $getfile[0]['saved_as'];
$spec = "php://filter/read=convert.iconv.cp932%2Futf-8/resource=$filename";
$file = new \SplFileObject($spec, 'rb');
$file->setFlags(
    \SplFileObject::READ_CSV |
    \SplFileObject::SKIP_EMPTY |
    \SplFileObject::READ_AHEAD |
    \SplFileObject::DROP_NEW_LINE
);
foreach ($file as $i => $row) {
    //1行目を読み飛ばす
    if ($i === 0) {
        continue;
    }
    var_dump($row);
}
//CSVデータ
name,options,explanation
POUCH-A,"COLOR BK BL WH

SIZE S M L","テスト

テスト"
POUCH-B,"","テスト

テスト"
//結果
//1件目のデータは COLOR BK BL WHの次の改行がなくなっています
//2件目のデータはテストの次の改行がなくなっています
array (size=3)
  0 => string 'POUCH-A' (length=7)
  1 => string 'COLOR BK BL WH
SIZE S M L' (length=26)
  2 => string 'テスト

テスト' (length=22)

/var/www/html/aaa/controller/upload.php:59:
array (size=3)
  0 => string 'POUCH-B' (length=7)
  1 => string '' (length=0)
  2 => string 'テスト
テスト' (length=20)
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

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

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

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

DROP_NEW_LINEの設定を外すと、改行はなくならないみたいですよ。
詳しくはわかりませんが、DROP_NEW_LINEの仕様かもしれませんね。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

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

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

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/12/29 18:29

    ありがとうございます!!
    確かにDROP_NEW_LINEは空行を読み飛ばす指定なのでそういう動作をしても不思議ではありませんね。
    SplFileObjectのパラメータオプションを変えて試してみるというのは全く頭になかったです。。
    まだまだ力不足ですがまた一つ勉強になりました。
    いつもありがとうございます。

    キャンセル

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

  • ただいまの回答率 89.11%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

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