laravelのコマンドでCSVを取込計算し出力を行っています。
現状出来てはいるのですが、現在の月で処理を止めたいですが上手くいきません。
if($break_key_year = $out_year && $break_key_month > $out_month){ break; }
上記を試しています。入れると崩れてしまいます。
$out_yearには2021
$out_monthには02
が入っております。
【コード】
<?php namespace App\Console\Commands; use Illuminate\Console\Command; use Illuminate\Support\Facades\Storage; use File; use Carbon\Carbon; class Output5 extends Command { /** * The name and signature of the console command. * * @var string */ protected $signature = 'command:output5'; /** * The console command description. * * @var string */ protected $description = '05'; /** * Create a new command instance. * * @return void */ public function __construct() { parent::__construct(); } /** * Execute the console command. * * @return int */ public function handle() { $test = storage_path('app/public/study05.csv'); $pf = fopen($test, 'r'); $test1 = fopen('public/storage/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; $old_year = $out_year -2; 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"); // fwrite($test1, $test3); if($test_date[0] < $out_year || $test_date[1] <= $out_month){ fwrite($test1, $test3); } } fclose($pf); fclose($test1); $filename = storage_path('app/public/test.csv'); $fp = fopen($filename, 'r'); if ($fp === false) { echo "ファイルオープン時に失敗したので処理終了します。" . PHP_EOL; exit; } $is_error = false; $break_key_year = ''; $break_key_month = ''; $i = 0; $nyukin = 0; // 入金 $syukin = 0; // 出金 $a = 0; $b = 0; while ($line = fgets($fp)) { $i++; // ファイル読込終了判定 if (feof($fp)) { break; } // ファイル読込エラー判定 if ($line === false) { echo "ファイル読込時に失敗したので処理終了します。" . PHP_EOL; $is_error = true; break; } // カンマ分割 $work_field = explode(',', $line); // 日付分割 $work_date = explode('/', $work_field[0]); $stock_nyukin[] = $work_field[1]; $total_nyukin = array_sum($stock_nyukin); $stock_syukin[] = $work_field[2]; $total_syukin = array_sum($stock_syukin); $now = Carbon::today(); $out_year = substr($now, 0, 4); $out_month = substr($now, 5, 2); // if($break_key_year = $out_year && $break_key_month = $out_month){ // break; // } // if($work_date[0] = $out_year && $work_date[1] = $out_month){ // break; // } if (($break_key_year != $work_date[0]) || ($break_key_month != $work_date[1])) { if ($i != 1) { echo $break_key_year . '年' . $break_key_month . '月' . '入金集計:' . $nyukin . '、出金合計:' . $syukin . PHP_EOL; $stock_year_nyukin[] = $nyukin; $year_nyukin = array_sum($stock_year_nyukin); $stock_year_syukin[] = $syukin; $year_syukin = array_sum($stock_year_syukin); $nyukin = 0; $syukin = 0; if (($break_key_year != $work_date[0])) { echo '---------------------------------------------------' . PHP_EOL; echo $break_key_year . '年:' . '入金合計:' . $year_nyukin . '、出金合計:' . $year_syukin . PHP_EOL; echo PHP_EOL; $keep1 = $year_nyukin; $keep2 = $year_syukin; } } $break_key_year = $work_date[0]; $break_key_month = $work_date[1]; } $w_nyukin = trim($work_field[1]); $w_syukin = trim($work_field[2]); if (empty($w_nyukin) && empty($w_syukin)) { echo $i . '行目のデータがありませんのでデータをスキップします。' . PHP_EOL; continue; } //通常処理 if (empty($w_nyukin)) { $syukin += $w_syukin; } else { $nyukin += $w_nyukin; } // if($break_key_year = $out_year && $break_key_month = $out_month){ // break; // } } $a = $total_nyukin - $keep1; $b = $total_syukin - $keep2; echo $break_key_year . '年' . $break_key_month . '月' . '入金集計:' . $nyukin . '、出金合計:' . $syukin . PHP_EOL; echo '---------------------------------------------------' . PHP_EOL; echo $break_key_year . '年:' . '入金合計:' . $a . '、出金合計:' . $b . PHP_EOL; echo PHP_EOL; echo '=========================================' . PHP_EOL; echo 'トータル:' . '入金合計:' . $total_nyukin . '、出金合計:' . $total_syukin . PHP_EOL; fclose($fp); if ($i == 0) { echo "指定されたファイルは空ファイルでした。" . PHP_EOL; } return 0; } }
以上、宜しくお願い致します。
回答1件
あなたの回答
tips
プレビュー