dousa2794 2017-06-01 10:15
浏览 167
已采纳

如何使用PhpSpreadsheet从表格单元格中检索日期?

I have xlsx tables and I use PhpSpreadsheet to parse them. Some cells format is date. The problem is that PhpSpreadsheet returns the values from date-formatted cells in an unspecified format:

// How it looks in excel: 2017.04.08 0:00
$value = $worksheet->getCell('A1')->getValue();  // 42833 - doesn't look like a UNIX time

How to get the date from a cell in form of a UNIX time or a DateTimeInterface instance?

  • 写回答

2条回答 默认 最新

  • duanjizi9443 2017-06-01 10:15
    关注

    The value is amount of days passed since 1900. You can use the PhpSpreadsheet built-in functions to convert it to a unix timestamp:

    $value = $worksheet->getCell('A1')->getValue();
    $date = \PhpOffice\PhpSpreadsheet\Shared\Date::excelToTimestamp($value);
    

    Or to a PHP DateTime object:

    $value = $worksheet->getCell('A1')->getValue();
    $date = \PhpOffice\PhpSpreadsheet\Shared\Date::excelToDateTimeObject($value);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?