今天使用laravel-excel导入excel中的日期,得到了一组含小数点的数字,如下图
在excel里明明是一个日期
经查资料,有如下解说
比方说,2015/5/20 15:47:37,文本格式为42144.6580671296
2015/1/12 15:47:49,文本格式为42016.6582060185
数字0转换为日期时间格式为1900/1/0 0:00:00
1为1900/1/1 0:00:00
1.007是1900/1/1 0:01:00
原来excel中表示日期的文本格式确实一组纯数字,而且这个纯数字就是一个偏移的值。这个偏移的值是距离1900/1/0 0:00:00
的一个天数值,2015/5/20
的文本格式42144.6580671296
正好是距离1900/1/0 0:00:00
的天数。
那么距离1900/1/0 0:00:00
的43123天正好就是2018后的某一天。43123/365=118.xxx年,1900+118=2018。
因为PHPExcel中将所有的列解析成文本格式,读出的时间是距离1900-01-01的偏移天数。
即excel 的日期是从 1900-01-01 开始计算的(php 是从 1970-01-01),两者间有一个天数差 42144.6580671296。时间是格林威治时间。
原成日期
知道了原理,代码就简单了:
$d = 25569; $t = 24 * 60 * 60; echo gmdate('Y-m-d H:i:s', (41728.732916667 - $d) * $t);
参考资料:https://tianshimanbu.com/basic/PHPExcel-date-43123.html
本帖已被设为精华帖!