天使漫步IT工作室

PHPExcel解释excel日期得到纯数字:43123 的解决办法

一、使用PHPExcel

今天使用PHPExcel解析excel中的日期,得到了一组纯数字,刚开始以为是乱码导致的(因为含有中文的列里面都出现了乱码),升级了PHPExcel以后(PHPExcel不更新已经两年,不过笔者还是悲催的在别的地方使用了更老的版本)。

升级完PHPExcel版本以后,含中文的列解析正常。但日期列解释依然异常,得到的结果还是43126(当时的日期记得是2018-3-12)。难道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。时间是格林威治时间。

三、php还原成日期

知道了原理,代码就简单了:

$d = date('Y-m-d',strtotime("+ ".$v['A']." days",strtotime('1900-01-01')));

$v['A']为excel的文本值,经过strtotime的转换,即还原为所需要的日期。

但是,以上代码还是会多2天!!!!

如果统一减掉2天,显然不符合程序常理。经过查找,发现PHPExcel有提供现成的api:

gmdate("Y-m-d H:i:s", PHPExcel_Shared_Date::ExcelToPHP(43123)

出来以后得到格林威治时间。

$d = 25569;

$t = 24 * 60 * 60;

echo gmdate('Y-m-d H:i:s', (41728.732916667 - $d) * $t);

得到格林豪治时间:2014-03-30 17:35:24。

当前页面是本站的「Google AMP」版。查看和发表评论请点击:完整版 »