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
?>


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM