jodatime在解析某些日期格式时的奇怪行为

时间:2013-11-11 15:31:55

标签: java datetime jodatime

我试图使用jodatime解析日期字符串,并在yyyy部分之前使用前导'+'。我预计会抛出一个错误,但实际上并没有抛出错误。我得到了没有任何意义的输出:

System.out.println(DateTimeFormat.forPattern("yyyyMMdd").parseDateTime("20130101"));
// 2013-01-01T00:00:00.000+05:30 (Expected) (case 1)

System.out.println(DateTimeFormat.forPattern("yyyyMMdd").parseDateTime("+20130101"));
// 20130-10-01T00:00:00.000+05:30 (??? Notice that month changed to 10 also) (case 2)

System.out.println(DateTimeFormat.forPattern("MMyyyydd").parseDateTime("01+201301"));
// 20130-01-01T00:00:00.000+05:30 (??? At least month is fine this time) (case 3)

System.out.println(DateTimeFormat.forPattern("MM-yyyy-dd").parseDateTime("01-+2013-01"));
// 2013-01-01T00:00:00.000+05:30 (I expected an error, but this parsed correctly) (case 4)

任何人都可以解释为什么会这样吗?我希望有一个例外,这意味着不允许使用“+”符号,或者它应该将+2013简单地解释为2013,这就是它在最后一种情况下的表现。但是案例2和案例3中的20130处理是什么,案例2中的月份= 10是什么?

3 个答案:

答案 0 :(得分:1)

如果你想在+标志上抛出异常,你可以使用DateTimeFormatterBuilder,它更灵活。
例如。格式为 yyyyMMdd

DateTimeFormatter dtf = new DateTimeFormatterBuilder()
         .appendFixedDecimal(DateTimeFieldType.year(), 4)
         .appendMonthOfYear(2)
         .appendDayOfMonth(2)
         .toFormatter();
dtf.parseDateTime("19990101");  - parsed correctly  
dtf.parseDateTime("-19990101"); - throw exception  
dtf.parseDateTime("+19990101"); - throw exception  

这种模式也已经出现在标准模式中:

ISODateTimeFormat::basicDate()

修改
但是在使用appendFixedSignedDecimal方法时存在奇怪的行为:

DateTimeFormatter dtf = new DateTimeFormatterBuilder()
         .appendFixedSignedDecimal(DateTimeFieldType.year(), 4)
         .appendMonthOfYear(2)
         .appendDayOfMonth(2)
         .toFormatter();
dtf.parseDateTime("19990101");  - parsed correctly  
dtf.parseDateTime("-19990101"); - parsed correctly   (negative years)  
dtf.parseDateTime("+19990101"); - throw exception (???)

我认为这是Joda lib中的问题,因为

DateTimeFormatter dtf = new DateTimeFormatterBuilder()
         .appendFixedSignedDecimal(DateTimeFieldType.year(), 4)
         .toFormatter();  

按预期工作

dtf.parseDateTime("1999");  - parsed correctly  
dtf.parseDateTime("-1999"); - parsed correctly (negative years)  
dtf.parseDateTime("+1999"); - parsed correctly   

(此案例出现在joda库的Unit Tests中)

答案 1 :(得分:1)

通过joda-time代码后,我能够缩小问题的范围。它是由于代码异常增加引起的。我已经打开了一个问题here。我也准备好了here。一旦得到确认,我会提出拉取请求是否是正确的解决方法。

答案 2 :(得分:0)

这不是答案,但可以帮助......:

    Case 1:        2013-01-01T00:00:00.000-05:00
    Case 2:        20130-10-01T00:00:00.000-04:00
    Case 3:        20130-01-01T00:00:00.000-05:00
    Case 4:        2013-01-01T00:00:00.000-05:00

请注意案例2如何更改时区。

我在ET时区并使用joda-time v2.3