java – 当本周的第一天是在上一年时,如何严格分析一个只有一年和一周的日期的日期?

我的目标是严格解析(例如禁止像98/99这样的日期).但是,以下代码引发了一个 java.text.ParseException,其中包含消息Unparseable date:“98/01”:
SimpleDateFormat sdf = new SimpleDateFormat("yy/ww");
sdf.setLenient(false);
sdf.parse("98/01");

这的确是first week of 1998,从星期四开始.然而,一周的解析总是返回本周第一天的日期.在这种情况下,将是1997年12月29日.这就是为什么会出现异常的原因.

看来这个问题来自于GregorianCalendar类,更具体地说来自于computeTime()方法,该方法检查当解析不宽松时,原始字段是否与外部设置的字段匹配:

if (!isLenient()) {
  for (int field = 0; field < FIELD_COUNT; field++) {
    if (!isExternallySet(field)) {
      continue;
    }

    if (originalFields[field] != internalGet(field)) {
      // Restore the original field values
      System.arraycopy(originalFields,fields,fields.length);
      throw new IllegalArgumentException(getFieldName(field));
    }
  }
}

这是一个bug吗?我认为1998/01年度的解析确实会回到1997年12月29日,并没有引起任何例外.但是,您是否知道如何使解析返回01/01/1998(这将是指定年份的一周的第一天)?

解决方法

我认为这应该适合你(你需要这个图书馆的时候):
public static Date parseYearWeek(String yearWeek) {
    DateTime dateTime = DateTimeFormat.forPattern("yy/ww").parseDateTime(yearWeek);

    if (dateTime.getWeekOfWeekyear() == 1 && dateTime.getMonthOfYear() == 12) {
        dateTime = DateTimeFormat.forPattern("yyyy/mm").parseDateTime((dateTime.getYear() + 1) + "/01");
    }

    return dateTime.toDate();
}

相关文章

Java中的String是不可变对象 在面向对象及函数编程语言中,不...
String, StringBuffer 和 StringBuilder 可变性 String不可变...
序列化:把对象转换为字节序列的过程称为对象的序列化. 反序...
先说结论,是对象!可以继续往下看 数组是不是对象 什么是对...
为什么浮点数 float 或 double 运算的时候会有精度丢失的风险...
面试题引入 这里引申出一个经典问题,看下面代码 Integer a ...