0

Excel 中的日期时间保存为自 1900-01-01 以来的天数(+1,因为它认为 1900-02-29 发生了)。数字中的分数是一天中的时间偏移量。

这个数字没有时区的概念。因此,在您打开电子表格的时区中,12.5 是 1900-01-12T12:00:00。在科罗拉多州打开它,它会显示中午。在德国打开它,它显示中午。这不是瞬间,而是 LocalDateTime。

对于我们将所有内容存储为 OffsetDateTime 或 ZonedDateTime (取决于日期时间如何传递给我们)的系统,我认为做的合乎逻辑的事情是从中创建一个 ZonedDateTime。

这导致了一个问题,如何在本地时区创建一个 ZonedDateTime,设置为此 Excel 日期时间数字?

4

1 回答 1

0
    LocalDate msBaseDate = LocalDate.of(1899, Month.DECEMBER, 31);

    double dateFromExcel = 12.5;
    long nanosSinceBase = Math.round(dateFromExcel * TimeUnit.DAYS.toNanos(1));
    ZonedDateTime dateTime = msBaseDate.atStartOfDay()
            .plusNanos(nanosSinceBase)
            .atZone(ZoneId.systemDefault());

    System.out.println(dateTime);

在我的电脑上,输出是:

1900-01-12T12:00+01:00[欧洲/哥本哈根]

由于 java.time 仅使用整数,因此我使用其最精细的粒度,纳秒。这将在 2192 年溢出 a long,因此对于面向未来的解决方案,您可以考虑单独添加整天,并且仅将分数转换为 nanos。

于 2019-03-15T11:26:23.333 回答