DateFormatter不挑剔?

时间:2010-11-02 15:52:17

标签: java

有没有人知道Java中的DateFormatter不那么挑剔?我的意思是我可以提供多种格式,可以写入日期,如果我提供的格式如下:

yyyy-MM-dd HH:mm:ss Z

用户可以输入:

2010-11-02 10:46:05 -0600
or
2010-11-02 10:46:05
or
2010-11-02 10:46
or
2010-11-02
or
2010-11-02 -0600

我可以创建一个DataFormat的实现,它使用List of DateFormat对象进行配置,并使我的实现在List中的每个对象中运行,直到一个人能够解析日期。所以,如果有人知道现有的日期格式化库比Java提供的那样挑剔/更灵活,我真的只是好奇。

2 个答案:

答案 0 :(得分:2)

看起来每个部件都有一个非常规则的格式,只是部件是可选的。我会使用具有每个部分的正则表达式(一些是可选的)。匹配该正则表达式并获取每个部分的组。然后以最完整的形式(“2010-11-02 10:46:05 -0600”)将它们放在一起,并让DateFormatter解析它。这样,如果缺少部件,您也可以控制部件的默认值。

以下是一些代码:

    Pattern p = Pattern
            .compile("(\\d{4}-\\d{2}-\\d{2})\\s*(\\d{2}:\\d{2})?(:\\d{2})?\\s*(\\+|-\\d{4})?");
    String[] strs = { "2010-11-02 10:46:05 -0600", "2010-11-02 10:46:05",
            "2010-11-02 10:46", "2010-11-02", "2010-11-02 -0600" };
    SimpleDateFormat format = new SimpleDateFormat("yyy-MM-dd HH:mm:ss Z");
    for (String s : strs) {
        Matcher m = p.matcher(s);
        if (m.matches()) {
            String hrmin = m.group(2) == null ? "00:00" : m.group(2);
            String sec = m.group(3) == null ? ":00" : m.group(3);
            String z = m.group(4) == null ? "+0000" : m.group(4);
            String t = String.format("%s %s%s %s", m.group(1), hrmin, sec,
                    z);
            System.out.println(s + " : " + format.parse(t));
        }
    }

输出:

2010-11-02 10:46:05 -0600 : Tue Nov 02 11:46:05 CDT 2010
2010-11-02 10:46:05 : Tue Nov 02 05:46:05 CDT 2010
2010-11-02 10:46 : Tue Nov 02 05:46:00 CDT 2010
2010-11-02 : Mon Nov 01 19:00:00 CDT 2010
2010-11-02 -0600 : Tue Nov 02 01:00:00 CDT 2010

答案 1 :(得分:1)

您可以查看方法

DateUtils.parse(String, String[])

来自apache commons / lang

。它允许您指定多个模式,所有模式都将被检查,直到可以成功解析日期。 (这与您自己建议的用法非常相似)。