php读取excel日期类型数据的例子

Excel中的日期,php读取之后,变成了类似25569这样的数字,而不是Excel中显示的1970-1-1字符形式,原来excel中的日期是个1900-1-1开始的数字格式,比如1900-1-1是1,1970-1-1是25569.

提供一个读取的函数,代码如下:

  1. //excel日期转换函数
  2. function excelTime($date, $time = false) {
  3. if(function_exists('GregorianToJD')){
  4. if (is_numeric( $date )) {
  5. $jd = GregorianToJD( 1, 1, 1970 );
  6. $gregorian = JDToGregorian( $jd + intval ( $date ) - 25569 );
  7. $date = explode( '/', $gregorian );
  8. $date_str = str_pad( $date [2], 4, '0', STR_PAD_LEFT )
  9. ."-". str_pad( $date [0], 2, '0', STR_PAD_LEFT )
  10. ."-". str_pad( $date [1], 2, '0', STR_PAD_LEFT )
  11. . ($time ? " 00:00:00" : '');//开源代码phpfensi.com
  12. return $date_str;
  13. }
  14. }else{
  15. $date=$date>25568?$date+1:25569;
  16. /*There was a bug if Converting date before 1-1-1970 (tstamp 0)*/
  17. $ofs=(70 * 365 + 17+2) * 86400;
  18. $date = date("Y-m-d",($date * 86400) - $ofs).($time ? " 00:00:00" : '');
  19. }
  20. return $date;
  21. }