在php中使用simplexlsx读取excel xlsx文件

MAK*_*MAK 10 php xlsx

我正在使用simplexlsx.class.php读取xlsx文件类型.当文件包含excel文件中的日期字段时,它会出现问题.

样本输出:

在文件数据中:

日期星期四2012年2月2日星期五2012年3月3日星期五

节目输出:

日期

周四40941
周五40942

它没有给出正确的日期

<?php

if (isset($_FILES['file'])) {

require_once "simplexlsx.class.php";

$xlsx = new SimpleXLSX( $_FILES['file']['tmp_name'] );

echo '<h1>Parsing Result</h1>';
echo '<table border="1" cellpadding="3" style="border-collapse: collapse">';

list($cols,) = $xlsx->dimension();

foreach( $xlsx->rows() as $k => $r) {
    if ($k == 0) continue; // skip first row
    echo '<tr>';
    for( $i = 0; $i < $cols; $i++)
    {

        echo '<td>'.( (isset($r[$i])) ? $r[$i] : '&nbsp;' ).'</td>';

    }
    echo '</tr>';
}
echo '</table>';
}

?>
<h1>Upload</h1>
<form method="post" enctype="multipart/form-data">
*.XLSX <input type="file" name="file"  />&nbsp;&nbsp;<input type="submit" value="Parse" />
Run Code Online (Sandbox Code Playgroud)

Mar*_*ker 11

这些是正确的日期,只是Excel的内部格式:自1900年1月1日以来的天数(允许1900年为闰年).显然,simplexlsx类中的某些东西是将xlsx日期值转换为Excel内部格式.

我以前没穿过simplexlsx来(这让我吃惊,因为我以为我知道所有PHP的Excel文件读/写库)......但在代码的某个地方一定有来处理转换的方法,所以我想象一下,还有一种反向方法(将Excel时间戳转换为PHP)

编辑

您想要的方法是在代码中:

function unixstamp( $excelDateTime ) {
    $d = floor( $excelDateTime ); // seconds since 1900
    $t = $excelDateTime - $d;
    return ($d > 0) ? ( $d - 25569 ) * 86400 + $t * 86400 : $t * 86400;
}
Run Code Online (Sandbox Code Playgroud)

我不保证它是准确的

编辑进一步

function unixstamp( $excelDateTime ) {
    $d = floor( $excelDateTime ); // seconds since 1900
    $t = $excelDateTime - $d;
    return ($d > 0) ? ( $d - 25569 ) * 86400 + $t * 86400 : $t * 86400;
}


$dateVal = 40941;
$unixDateVal = unixstamp($dateVal);
var_dump($unixDateVal);
echo date('d-M-Y',$unixDateVal);
Run Code Online (Sandbox Code Playgroud)

float 1328140800
Run Code Online (Sandbox Code Playgroud)

这看起来非常类似于今年正确范围内的unix时间戳值,当然可以:

02-Feb-2012
Run Code Online (Sandbox Code Playgroud)

看起来它对我有用