我想从以下模式解析LocalDateTime:
yyyyMMddHHmmss000000
这意味着通常" yyyy ... ss"然后是六个尾随零。
因此,格式化工作正常:
String p = "yyyyMMddHHmmss'000000'";
LocalDateTime.now().format(DateTimeFormatter.ofPattern(p));
但解析:
String p, v;
p = "yyyyMMddHHmmss"; // without '000000'
v = "20160131235930";
LocalDateTime.parse(v, DateTimeFormatter.ofPattern(p)); // it works
p = "yyyy-MMddHHmmss'000000'"; // with '-' in between
v = "2016-0131235930000000";
LocalDateTime.parse(v, DateTimeFormatter.ofPattern(p)); // it works
p = "yyyyMMddHHmmss'000000'"; // with '000000' but without '-'
v = "20160131235930000000";
LocalDateTime.parse(v, DateTimeFormatter.ofPattern(p)); // it throws Exception
例外:
java.time.format.DateTimeParseException: Text '20160131235930000000' could not be parsed at index 0
at java.time.format.DateTimeFormatter.parseResolved0(DateTimeFormatter.java:1947)
at java.time.format.DateTimeFormatter.parse(DateTimeFormatter.java:1849)
at java.time.LocalDateTime.parse(LocalDateTime.java:492)
...
我无法更改输入值的格式。我该如何正确解析它?我的模式错了吗?
Java版本:OSX上的1.8.0_60
答案 0 :(得分:9)
这看起来像是DateTimeFormatter
的错误及其对可变宽度输入的处理。
使用DateTimeFormatterBuilder
构建以下格式化程序可以解决问题
DateTimeFormatter formatter =
new DateTimeFormatterBuilder().appendValue(ChronoField.YEAR, 4)
.appendValue(ChronoField.MONTH_OF_YEAR, 2)
.appendValue(ChronoField.DAY_OF_MONTH, 2)
.appendValue(ChronoField.HOUR_OF_DAY, 2)
.appendValue(ChronoField.MINUTE_OF_HOUR, 2)
.appendValue(ChronoField.SECOND_OF_MINUTE, 2)
.appendLiteral("000000")
.toFormatter();
不同之处在于它强制字段的宽度用appendValue(field, width)
进行解析。
这个错误听起来类似于提到in another answer of mine的错误,尽管它在模式中提到了毫秒而不是文字字符。