laravelのコマンドでCSV読み込みや書き込みをしています。
上記を読み込み今月まで書き込み新たにファイルを作っています。
上記でいうと2019/01/01とと2021/03/01と2021/04/01のデータがいらない。
$test_date[0] > $old_year
上記で2020年以前削除
$test_date[0] < $out_year || $test_date[1] <= $out_month
上記で2021年2月以降削除
両方満たすやり方がわかりません。
【現状コード】
$open = storage_path('app/public/study05.csv'); $fp = fopen($open, 'r'); $edit = fopen('public/storage/test.csv', 'w'); if ($fp === false) { echo "ファイルオープン時に失敗したので処理終了します。" . PHP_EOL; exit; } $now = Carbon::today(); $out_year = substr($now, 0, 4); $out_month = substr($now, 5, 2); $i = 0; $old_year = $out_year -2; while ($line1 = fgets($fp)) { $i++; // カンマ分割 $test_field = explode(',', $line1); // 日付分割 $test_date = explode('/', $test_field[0]); $write = $test_field[0].','.$test_field[1].','.$test_field[2]; $mojiok = mb_convert_encoding("$write", "SJIS-win"); // fwrite($test1, $test3); if($test_date[0] < $out_year || $test_date[1] <= $out_month){ fwrite($edit,$mojiok); } } fclose($fp); fclose($edit);
以上、宜しくお願い致します。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。