之前写过关于maatwebsite/excel导出的简单用法,今天来看下导入的使用
file('file'); $type = $request->input('type'); Excel::import(new ImportService($type), $file); return $this->success(true); }}
我这里使用的是array,同时maatwebsite/excel还支持(ToCollection)集合,(ToModel)model这两种方式导入
type = $type; } public function array (array $array): void { switch ($this->type) { case 'pay': break; case 'gm': break; case 'create': break; case 'active': break; default: $this->handleData($array); // dd( Carbon::parse('1970-01-01')->addDays(44707-25569)->toDateTimeString()); // 结果 2022-05-26 00:00:00 break; } } public function handleData (array $array) { // 去除表头 unset($array[0]); $dateTime = Carbon::now()->toDateTimeString(); collect($array)->chunk(1000)->map(function ($value) use ($dateTime) { $insertData = collect($value)->map(function ($val) use ($dateTime) { return [ 'date' => Carbon::parse('1970-01-01')->addDays($val[0]-25569)->toDateTimeString(), 'name' => $val[1], 'status' => $val[2], 'created_at' => $dateTime, 'updated_at' => $dateTime, ]; })->toArray(); // 插入数据 }); }}
这里的时间需要单独处理,excel使用的时间是格林威治时间,所以我们在使用excel导入时间的时候需要特别注意,时间会被转为从1900-01-01日开始计算的天数,而EXCEL中1970-01-01天数为25569,所以我们在计算excel中的时间的时候应该先减去25569天
以上就是导入的全部过程, 希望对大家有所帮助
来源地址:https://blog.csdn.net/mercy_php/article/details/126999306