laravelのコマンドでCSV読み込みや書き込みをしています。
上記を読み込み今月まで書き込み新たにファイルを作っています。
上記でいうと2021/03/01のデータがいらない。
$test = storage_path('app/public/study05.csv'); $pf = fopen($test, 'r'); $test1 = fopen('test.csv', 'w'); if ($pf === false) { echo "ファイルオープン時に失敗したので処理終了します。" . PHP_EOL; exit; } $now = Carbon::today(); $out_year = substr($now, 0, 4); $out_month = substr($now, 5, 2); $i = 0; while ($line1 = fgets($pf)) { $i++; // カンマ分割 $test_field = explode(',', $line1); // 日付分割 $test_date = explode('/', $test_field[0]); $test2 = $test_field[0].','.$test_field[1].','.$test_field[2]; $test3 = mb_convert_encoding("$test2", "SJIS-win"); if($test_date[0] < $out_year || $test_date[1] <= $out_month){ fwrite($test1, $test3); } } fclose($pf); fclose($test1);
上記のように組んだのですが、fwrite($test1, $test3);のところで
fwrite(): supplied resource is not a valid stream resource
のエラーが出ます。fopenが上手くいってないなどありましたが、
値は取れているのでfopen出来ていると思うのですが、何が原因でしょうか?
回答1件
あなたの回答
tips
プレビュー