From aad79488715ceb301000eaafb9cfde8f06d05118 Mon Sep 17 00:00:00 2001 From: erdar2 Date: Wed, 22 Dec 2021 22:37:15 +0100 Subject: [PATCH] chore: improved scraping algorithm by only adding one record per day --- .../Commands/DispatchUpdateManually.php | 43 +++++++++++++++++++ app/Jobs/UpdateCovidData.php | 22 ++++++++-- 2 files changed, 62 insertions(+), 3 deletions(-) create mode 100644 app/Console/Commands/DispatchUpdateManually.php diff --git a/app/Console/Commands/DispatchUpdateManually.php b/app/Console/Commands/DispatchUpdateManually.php new file mode 100644 index 0000000..f05e809 --- /dev/null +++ b/app/Console/Commands/DispatchUpdateManually.php @@ -0,0 +1,43 @@ +delete(); + $data_arr = []; foreach ($res->collect() as $data) { + //dd(Carbon::createFromFormat('Y-m-d', $data["lastUpdatedAtApify"])); try { + $attr = []; $attr["infected"] = $data["infected"] ?? null; $attr["deceased"] = $data["deceased"] ?? null; @@ -45,12 +48,25 @@ class UpdateCovidData implements ShouldQueue $attr["quarantined"] = $data["quarantined"] ?? null; $attr["tested"] = $data["tested"] ?? null; $attr["created_at"] = Carbon::createFromFormat('Y-m-d\TH:i:s+', $data["lastUpdatedAtApify"]); - $d = new CovidData($attr); - $d->save(); + $idx = Carbon::parse($data["lastUpdatedAtApify"])->format('Y-m-d'); + if(!isset($data_arr[$idx])){ + $data_arr[$idx] = $attr; + }else if($attr["created_at"] > $data_arr[$idx]["created_at"]){ + $data_arr[$idx]["infected"] == $attr["infected"] ?? $data_arr[$idx]["infected"]; + $data_arr[$idx]["deceased"] == $attr["deceased"] ?? $data_arr[$idx]["deceased"]; + $data_arr[$idx]["recovered"] == $attr["recovered"] ?? $data_arr[$idx]["recovered"]; + $data_arr[$idx]["quarantined"] == $attr["quarantined"] ?? $data_arr[$idx]["quarantined"]; + $data_arr[$idx]["tested"] == $attr["tested"] ?? $data_arr[$idx]["tested"]; + $data_arr[$idx]["created_at"] = $attr["created_at"]; + } } catch (\Exception $e) { dd($data, $e); } - }; + } + foreach($data_arr as $attr){ + $d = new CovidData($attr); + $d->save(); + } //dd(CovidData::all()); } }