8

我试图使用 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 是怎么回事?

4

3 回答 3

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 库的单元测试中)

于 2013-11-12T18:38:40.947 回答
1

在浏览了 joda-time 代码之后,我能够缩小问题的范围。这是由于代码中的异常增量引起的。我在这里打开了一个问题。我这里也准备好了一个修复程序。一旦我确认这是修复它的正确方法,我会提出一个拉取请求。

于 2013-11-13T13:18:18.467 回答
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

于 2013-11-12T16:35:41.167 回答