微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

带有可选部分的Java 8 DateTimeFormatter

我有一个字符串代表日期(有或没有时间),如13/12/2017或13/12/2017 15:39:51

所以我正在尝试将java 8 DateTimeFormatter与可选部分一起使用.

代码有效

LocalDateTime localDateTime = LocalDateTime.parse("13/12/2017 15:39:51",DateTimeFormatter.ofPattern("dd/MM/yyyy[ HH:mm:ss]"));
System.out.println(localDateTime.format(DateTimeFormatter.ofPattern("dd/MM/yyyy")));
System.out.println(localDateTime.format(DateTimeFormatter.ofPattern("HH:mm:ss")));

13/12/2017
15:39:51

但我不明白为什么那个没有

LocalDateTime localDateTime = LocalDateTime.parse("13/12/2017",DateTimeFormatter.ofPattern("dd/MM/yyyy[ HH:mm:ss]"));

给我

Exception in thread "main" java.time.format.DateTimeParseException: Text '13/12/2017' Could not be parsed: Unable to obtain LocalDateTime from TemporalAccessor: {},ISO resolved to 2017-12-13 of type java.time.format.Parsed
at java.time.format.DateTimeFormatter.createError(DateTimeFormatter.java:1920)
at java.time.format.DateTimeFormatter.parse(DateTimeFormatter.java:1855)
at java.time.LocalDateTime.parse(LocalDateTime.java:492)
...

甚至还有

LocalDateTime localDateTime = LocalDateTime.parse("13/12/2017",DateTimeFormatter.ofPattern("dd/MM/yyyy"));

它不适用于相同的例外.

解决方法

使用 parseBest

使用可选组件时,应使用parseBest进行解析.你的应用程序可能只使用解析,但那只是运气(因为你只解析完整的输入,而不是部分输入).使用parseBest,您可以正确处理各种TemporalAccessor,这是使用可选的全部原因.

返回TemporalAccessor的决定相当简单:parseBest将尝试按参数顺序匹配每个TemporalQuery.当任何匹配时,该方法返回该匹配.因此,请确保从最精确到最精确.此外,如果没有匹配,则会抛出异常.

LocalDateTime dateTime;
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("dd/MM/yyyy[ HH:mm:ss]");
TemporalAccessor temporalAccessor = formatter.parseBest("13/12/2017",LocalDateTime::from,LocalDate::from);
if (temporalAccessor instanceof LocalDateTime) {
  dateTime = (LocalDateTime)temporalAccessor;
} else {
  dateTime = ((LocalDate)temporalAccessor).atStartOfDay();
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐