我有下一个字符串:2000-01-01T01:01:01
和2000-01-01T01:01:01.000Z
是否可以使用ISODateTimeFormat
来解析这两个日期?
答案 0 :(得分:3)
您可以使用dateTimeParser()。它的描述承诺:
It accepts formats described by the following syntax:
datetime = time | date-opt-time
time = 'T' time-element [offset]
date-opt-time = date-element ['T' [time-element] [offset]]
date-element = std-date-element | ord-date-element | week-date-element
std-date-element = yyyy ['-' MM ['-' dd]]
ord-date-element = yyyy ['-' DDD]
week-date-element = xxxx '-W' ww ['-' e]
time-element = HH [minute-element] | [fraction]
minute-element = ':' mm [second-element] | [fraction]
second-element = ':' ss [fraction]
fraction = ('.' | ',') digit+
offset = 'Z' | (('+' | '-') HH [':' mm [':' ss [('.' | ',') SSS]]])
<强>测试强>
String s1 = "2000-01-01T01:01:01.000Z";
String s2 = "2000-01-01T01:01:01";
DateTime dt1 = ISODateTimeFormat.dateTimeParser().withOffsetParsed().parseDateTime(s1);
System.out.println(dt1); // 2000-01-01T01:01:01.000Z
DateTime dt2 = ISODateTimeFormat.dateTimeParser().withOffsetParsed().parseDateTime(s2);
System.out.println(dt2); // 2000-01-01T01:01:01.000+01:00 (using default zone)
当然,没有偏移的字符串在某种程度上是可疑的。你决定如何解释结果resp。在哪个时区,因为文本输入的某些部分缺少此信息。
就个人而言,我希望Joda-Time能够优先考虑已解析的偏移信息,但在文本输入没有偏移的情况下选择用户定义的时区偏移(Joda-Time只允许设置用户) - formatter.withZone(...)
定义的区域,它优先于文本输入中的任何可用偏移信息 - 不太理想。