php读取excel的日期是数字,PHPExcel 解释 Excel日期得到纯数字 (含小数点) 的解决办法...

今天使用laravel-excel导入excel中的日期,得到了一组含小数点的数字,如下图

b9e161baab20c9a892b7dfe86130a6dc.png

在excel里明明是一个日期

a0879d6314e6f2cfdabfacb8c3bc2b99.png

经查资料,有如下解说比方说,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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值