DateTimeFormatter 中的 Formatter for ISO 8601 日期格式的时间

Formatter in DateTimeFormatter for ISO 8601 date format of the time

我有一个关于 DateTimeFormatter 格式化程序的问题。

在 SWAPI (https://swapi.co/documentation#people) 中,您可以阅读 creatededited 日期,格式如下所示:

2014-12-09T13:50:51.644000Z

这个日期的描述是:

但是在 Class DateTimeFormatterPredefined Formatters 部分的文档中,我看不到任何与SWAPI 日期示例。

问题是,当我尝试解析它时,正在使用 SSSSSS:

DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.SSSSSS'Z'")

nnnnnn:

DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.nnnnnn'Z'")

知道哪一个是正确的格式化程序吗?

根据您的情况,您可能根本不需要指定格式化程序。 java.time 的 类 解析(和打印)ISO 8601 格式作为它们的默认格式,即没有任何显式格式化程序。正如你图片中的描述所说,这是你得到的格式。

但是,您要链接的两个预定义格式化程序与您的示例匹配:

  1. ISO_INSTANT
  2. ISO_OFFSET_DATE_TIME

使用哪一个取决于对要将字符串解析成的类型的任何要求。解析成一个Instant是最简单的。不要指定格式化程序,只需使用 Instant.parse:

    String swapiCreatedString = "2014-12-09T13:50:51.644000Z";
    Instant created = Instant.parse(swapiCreatedString);
    System.out.println("Created " + created);

输出:

Created 2014-12-09T13:50:51.644Z

我需要进一步操作解析的日期时间,例如为用户格式化它,OffsetDateTime 提供更多可能性:

    OffsetDateTime created = OffsetDateTime.parse(swapiCreatedString);

同样不需要格式化程序来进行解析。输出与上面相同。

我想您没有看到上述两个格式化程序匹配的原因包括:

  • None 示例包括秒的小数部分,但格式化程序接受 0 到 9 位小数(含)的小数秒。
  • 示例偏移日期时间有偏移 +01:00。您可能不知道 Z 也可以用作偏移量。它发音为“Zulu”并表示 UTC。

更直接地回答您的问题:None 您的格式非常正确。因为正如我所说 Z 是一个偏移量,所以您将希望按原样而不是文字来解析它,以便从字符串中获取偏移量信息。没有它,您将不知道在哪个偏移量处解释 13:50:51.644。 .SSSSSS 对于秒的小数部分是正确的,而 .nnnnnn 表示秒的纳秒并且在这里是不正确的。一秒有 10^9 纳秒,所以 n 只有在有 9 位纳秒的情况下才有效。也许你自己的例子给出了最好的说明:

    // nnnnnn is incorrect
    DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd'T'HH:mm:ss.nnnnnn'Z'");
    String swapiCreatedString = "2014-12-09T13:50:51.644000Z";
    LocalDateTime created = LocalDateTime.parse(swapiCreatedString, formatter);
    System.out.println("Created " + created);

Created 2014-12-09T13:50:51.000644

您看到 51.644 秒被错误地更改为 51.000644