下面來看一個關于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
- ?>//開源軟件:Vevb.com
新聞熱點
疑難解答