php把excel数值格式转成日期格式
程序员文章站
2023-12-31 16:31:52
在excel中:40847对应2011-10-31,是日期的数值型表现形式。在PHP中,echo date('Y-m-d H:i:s',40847);//结果1970-01-01 11:52:30 原因:PHP 的时间函数是从1970-1-1日开始计算的,单位是秒数。但是 EXCEL的是从1900- ......
在excel中:40847对应2011-10-31,是日期的数值型表现形式。
在php中,echo date('y-m-d h:i:s',40847);//结果1970-01-01 11:52:30
原因:
php 的时间函数是从1970-1-1日开始计算的,单位是秒数。但是 excel的是从1900-1-1日开始算的单位是天数。
如果只计算1970以后的时间的话,就好处理了。
先获得 excel中 1970-1-1 代表的数字,我查了是25569。
现在要把excel中的40947,在php中用函数正确的显示出来
function _excelnumtodate($num)
{
$date = '';
if ($num == (int)$num) {
//获得秒数
$time = ($num - 25569) * 24 * 60 * 60;
return date('y-m-d', $time);
}
return $date;
}
推荐阅读
-
php通过imagick库把PDF转成PNG格式
-
php 利用openoffice把office转成pdf格式,该怎么解决
-
PHP中把Excel中4位数的日期格式变成年月日格式
-
php 利用openoffice把office转成pdf格式,该怎么处理
-
php把excel数值格式转成日期格式
-
php 利用openoffice把office转成pdf格式,该怎么处理
-
php 利用openoffice把office转成pdf格式,该如何处理
-
php 利用openoffice把office转成pdf格式,该怎么处理
-
php如何把数据库数据转成json格式,例如"phone":"123456"改为"name":"phone","value":"123456"
-
php 利用openoffice把office转成pdf格式,该怎么解决