我创建了 Excel 导入函数,它工作正常,直到我注意到日期没有正确插入,所以我尝试格式化日期,就像Y-m-d在 MySql 中正确存储一样,但 Carbon 给出了以下错误
Carbon\Exceptions\InvalidFormatException
发现意外数据。发现意外数据。追踪数据
在Excel中我可能有d/m/Y或者Y/m/d所以我想在数据库中格式化为tored
我的导入代码
public function model(array $row)
{
return new Staff([
'employee_no' => $row['id'],
'name' => $row['name'],
'address' => $row['address'],
'fathers_name' => $row['father'],
'dob' => $this->transformDate($row['dob']),
'blood_group' => $row['blood_group'],
'phone' => $row['phone'],
'password' => Hash::make($row['id']),
]);
}
public function transformDate($value, $format = 'Y-m-d')
{
try {
return \Carbon\Carbon::instance(\PhpOffice\PhpSpreadsheet\Shared\Date::excelToDateTimeObject($value));
} catch (\ErrorException $e) {
return \Carbon\Carbon::createFromFormat($format, $value);
}
}
我的员工模型
class Staff extends Authenticatable
{
protected $fillable = [
'name', 'employee_no', 'designation_id', 'fathers_name', 'dob', 'identification_mark', 'blood_group', 'phone', 'address', 'height', 'rfid_no', 'building_id', 'password',
];
protected $casts = ['dob'];
}
正确的方法是什么,还是我必须采用新的format方法dob
杨__羊羊