这有点复杂.
As jvdmr says,Xs的数量很重要. XXXXX将识别-08:30:15,但不是-083015. XXXX将承认后者,但不承认前者.
为了考虑所有可能的示例格式,我们需要指定不同的可能性.这可以使用方括号在格式模式字符串中完成.这些包含可选部件.一些实验表明,以下模式涵盖了所有示例:
uuuu-MM-dd'T'HH:mm:ss[XXXXX][XXXX][X]
我们来试试吧:
DateTimeFormatter formatter
= DateTimeFormatter.ofPattern("uuuu-MM-dd'T'HH:mm:ss[XXXXX][XXXX][X]");
for (String dts : new String[] {
"2014-01-01T00:30:00-08:30:15", "2014-01-01T00:30:00-083015",
"2014-01-01T00:30:00-08:30", "2014-01-01T00:30:00-0830",
"2014-01-01T00:30:00-08", "2014-01-01T00:30:00Z",
}) {
System.out.println(OffsetDateTime.parse(dts, formatter));
}
此代码段的输出是:
06001
编辑
VelNaga suggests不要硬编码ISO日期时间格式.由于编写格式模式字符串容易出错,因此这可能是一个好主意.例如:
DateTimeFormatter formatter = new DateTimeFormatterBuilder()
.append(DateTimeFormatter.ISO_LOCAL_DATE_TIME)
.appendPattern("[XXXXX][XXXX][X]")
.toFormatter();
使用此格式化程序的输出与使用上述格式化程序的输出相同.它更啰嗦,但我们很容易认为这是值得的,因为它不易出错,可能更清晰,更容易阅读.