欢迎光临
我们一直在努力

php读取excel指定单元格内容,phpexcel日期格式转换

今天使用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-4312香港vps3.html

00245306

赞(0)
【声明】:本博客不参与任何交易,也非中介,仅记录个人感兴趣的主机测评结果和优惠活动,内容均不作直接、间接、法定、约定的保证。访问本博客请务必遵守有关互联网的相关法律、规定与规则。一旦您访问本博客,即表示您已经知晓并接受了此声明通告。