0

我正在使用 ubuntu 进行编码。,

我正在将 xls 文件数据导入我的控制器,其中一个字段是日期,我已经用日期格式格式化了单元格,当我查看导入的数据时一切都很好,但日期字段显示为数字,

例如:输入的日期是否2013-05-10显示为39942

然后检查我已经通过保持日期值原样将单元格的格式更改为数字然后它向我显示了一个39942与我进入控制器的值相同的值..!导入后如何获得正确的日期,

对此有任何帮助..?

4

1 回答 1

0

Excel 将日期/时间存储为序列化的浮点时间戳、自 1900 年 1 月 1 日(或 1904 年 1 月 1 日,取决于 Windows 或 Mac 日历)以来的天数,并记住它将 1900 年视为闰年。

直接取自 PHPExcel 日期处理代码:

public static function ExcelToPHP($dateValue = 0) {
    if (self::$ExcelBaseDate == self::CALENDAR_WINDOWS_1900) {
        $myExcelBaseDate = 25569;
        //    Adjust for the spurious 29-Feb-1900 (Day 60)
        if ($dateValue < 60) {
            --$myExcelBaseDate;
        }
    } else {
        $myExcelBaseDate = 24107;
    }

    // Perform conversion
    if ($dateValue >= 1) {
        $utcDays = $dateValue - $myExcelBaseDate;
        $returnValue = round($utcDays * 86400);
        if (($returnValue <= PHP_INT_MAX) && ($returnValue >= -PHP_INT_MAX)) {
            $returnValue = (integer) $returnValue;
        }
    } else {
        $hours = round($dateValue * 24);
        $mins = round($dateValue * 1440) - round($hours * 60);
        $secs = round($dateValue * 86400) - round($hours * 3600) - round($mins * 60);
        $returnValue = (integer) gmmktime($hours, $mins, $secs);
    }

    // Return
    return $returnValue;
}    //    function ExcelToPHP()

根据需要设置 self::$ExcelBaseDate == self::CALENDAR_WINDOWS_1900 以指示您正在使用的 Excel 基准日历:Windows 1900 或 Mac 1904

如果你想要一个 PHP DateTime 对象:

public static function ExcelToPHPObject($dateValue = 0) {
    $dateTime = self::ExcelToPHP($dateValue);
    $days = floor($dateTime / 86400);
    $time = round((($dateTime / 86400) - $days) * 86400);
    $hours = round($time / 3600);
    $minutes = round($time / 60) - ($hours * 60);
    $seconds = round($time) - ($hours * 3600) - ($minutes * 60);

    $dateObj = date_create('1-Jan-1970+'.$days.' days');
    $dateObj->setTime($hours,$minutes,$seconds);

    return $dateObj;
}    //    function ExcelToPHPObject()
于 2013-05-10T13:08:23.047 回答