|
|
@@ -0,0 +1,74 @@
|
|
|
+<?php
|
|
|
+
|
|
|
+namespace App\Console\Commands;
|
|
|
+
|
|
|
+use Illuminate\Console\Command;
|
|
|
+use App\Models\Wbw;
|
|
|
+use Illuminate\Support\Facades\Storage;
|
|
|
+use Carbon\Carbon;
|
|
|
+
|
|
|
+class StatisticsWbw extends Command
|
|
|
+{
|
|
|
+ /**
|
|
|
+ * The name and signature of the console command.
|
|
|
+ *
|
|
|
+ * @var string
|
|
|
+ */
|
|
|
+ protected $signature = 'statistics:wbw';
|
|
|
+
|
|
|
+ /**
|
|
|
+ * The console command description.
|
|
|
+ *
|
|
|
+ * @var string
|
|
|
+ */
|
|
|
+ protected $description = '统计 wbw 每月建立数量';
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Create a new command instance.
|
|
|
+ *
|
|
|
+ * @return void
|
|
|
+ */
|
|
|
+ public function __construct()
|
|
|
+ {
|
|
|
+ parent::__construct();
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Execute the console command.
|
|
|
+ *
|
|
|
+ * @return int
|
|
|
+ */
|
|
|
+ public function handle()
|
|
|
+ {
|
|
|
+ $file = "public/statistics/wbw-monthly.csv";
|
|
|
+ Storage::disk('local')->put($file, "");
|
|
|
+ #按月获取数据
|
|
|
+ $firstDay = Wbw::select('created_at')
|
|
|
+ ->orderBy('created_at')
|
|
|
+ ->first();
|
|
|
+ $firstDay = strtotime($firstDay->created_at);
|
|
|
+ $firstMonth = Carbon::create(date("Y-m",$firstDay));
|
|
|
+ $now = Carbon::now();
|
|
|
+ $current = $firstMonth;
|
|
|
+ $sumCount = 0;
|
|
|
+ while ($current <= $now) {
|
|
|
+ # code...
|
|
|
+ $start = Carbon::create($current)->startOfMonth();
|
|
|
+ $end = Carbon::create($current)->endOfMonth();
|
|
|
+ $date = $current->format('Y-m');
|
|
|
+ $count = Wbw::whereDate('created_at','>=',$start)
|
|
|
+ ->whereDate('created_at','<=',$end)
|
|
|
+ ->count();
|
|
|
+ $sumCount += $count;
|
|
|
+ $editor = Wbw::whereDate('created_at','>=',$start)
|
|
|
+ ->whereDate('created_at','<=',$end)
|
|
|
+ ->groupBy('editor_id')
|
|
|
+ ->select('editor_id')->get();
|
|
|
+ $info = $date.','.$count.','.$sumCount.','.count($editor);
|
|
|
+ $this->info($info);
|
|
|
+ Storage::disk('local')->append($file, $info);
|
|
|
+ $current->addMonth(1);
|
|
|
+ }
|
|
|
+ return 0;
|
|
|
+ }
|
|
|
+}
|