2009年7月14日星期二

用DateFormat的parse方法验证字符串是否是日期的问题

因为最近比较闲 有点不思进取 也没什么问题要写了
今天不错,发现一个,恩,感觉不错
做了一个上传Excel并解析数据然后入库的功能,里面涉及到是否是日期格式的判断
之前是这么写的(深谙这么写是不好的,但以为它是可靠的)

private boolean checkDate(String content) {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        try {
            sdf.parse(content);
            return true;
        } catch (Exception e){
            return false;
        }
    }

现在发现问题了,对于“2008-06-23asdf”这种情况是返回true的,哈哈,看来是孤陋寡闻了,基础不扎实了,看API上这样讲:

在默认情况下,进行的分析是不严格的:如果输入的形式不是此对象的格式化方法使用的形式,但仍可作为日期进行分析,则分析将获得成功。客户机可能通过调用 setLenient(false) 来强调严格遵守该格式。


按照API说法,将代码改成
private boolean checkDate(String content) {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        try {
            sdf. setLenient(false);
            sdf.parse(content);
            return true;
        } catch (Exception e){
            return false;
        }
    }

运行结果“2008-06-23asdf”这种情况还是返回true的,但“2008-13-23”这种情况是返回false的
最后改进程这种写法,可以适应"yyyy-MM-dd""yyyy-M-d""yyyy-MM-d""yyyy-M-dd"

private boolean checkDate(String content) {
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-M-d");
        try {
            sdf.setLenient(false);
            content = content.replaceAll("-0", "-");
            Date d = sdf.parse(content);
            String s = sdf.format(d);
            return content.equals(s);
        } catch (Exception e){
            return false;
        }
    }

参考资料http://www.99inf.net/SoftwareDev/Java/52734.htm
              http://blog.163.com/everlee@126/blog/static/263574220089822631229/

当然也可以用正则表达式做到。

没有评论:

发表评论