萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> php把excel數值格式轉成日期格式問題

php把excel數值格式轉成日期格式問題

下面來看一個關於php把excel數值格式轉成日期格式問題,因為自己在做一個轉換時碰到問題,後來網上找到解決辦法與原因下面一起看看。

在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中用函數正確的顯示出來

代碼如下:
<?php
  $time = (40847 – 25569) * 24*60*60; //獲得秒數
  echo date('Y-m-d H:i:s', $time);   //出來 2011-10-31
?>

copyright © 萬盛學電腦網 all rights reserved