Java:不可解析的日期异常

2022-09-01 09:29:15

在尝试转换日期格式时,我得到一个异常:不可解析的日期,不知道如何解决这个问题。

我收到一个表示事件日期的字符串,并希望在GUI中以不同的格式显示此日期。

我试图做的是以下几点:

private String modifyDateLayout(String inputDate){
        try {
            //inputDate = "2010-01-04 01:32:27 UTC";
            Date date = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss z").parse(inputDate);
            return new SimpleDateFormat("dd.MM.yyyy HH:mm:ss").format(date);
        } catch (ParseException e) {
            e.printStackTrace();
            return "15.01.2010";
        }
    }

反正线

String modifiedDateString = originalDate.toString();

是假人。我想得到以下格式的日期字符串:

dd.mm.yyyy HH:mm:ss

输入字符串示例如下:

2010-01-04 01:32:27 UTC

有谁知道如何将上面的示例日期(字符串)转换为字符串格式dd.MM.yyyy HH:mm:ss?

谢谢!

编辑:我修复了错误的输入日期格式,但仍然不起作用。上面是粘贴的方法,下面是调试会话的屏幕图像。

替代文本 http://img683.imageshack.us/img683/193/dateproblem.png

#Update我跑了

String[] timezones = TimeZone.getAvailableIDs();

并且数组中有 UTC 字符串。这是一个奇怪的问题。

我做了一个肮脏的黑客工作:

private String modifyDateLayout(String inputDate){
    try {
        inputDate = inputDate.replace(" UTC", "");
        Date date = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(inputDate);
        return new SimpleDateFormat("dd.MM.yyyy HH:mm:ss").format(date);
    } catch (ParseException e) {
        e.printStackTrace();
        return "15.01.2010";
    }
}

但我仍然更愿意在不削减时区的情况下转换原始输入。

此代码是为使用 JDK 1.6 的 Android 手机编写的。


答案 1

你在这里所做的基本上是依靠Date#toString(),它已经有一个固定的模式。要将Java对象转换为另一个人类可读的字符串模式,您需要SimpleDateFormat#format()Date

private String modifyDateLayout(String inputDate) throws ParseException{
    Date date = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss z").parse(inputDate);
    return new SimpleDateFormat("dd.MM.yyyy HH:mm:ss").format(date);
}

顺便说一句,“不可解析的日期”异常在这里只能SimpleDateFormat#parse()引发。这意味着 不在预期的模式中。您可能需要修改模式以匹配 的实际模式。inputDate"yyyy-MM-dd HH:mm:ss z"inputDate

更新:好的,我做了一个测试:

public static void main(String[] args) throws Exception {
    String inputDate = "2010-01-04 01:32:27 UTC";
    String newDate = new Test().modifyDateLayout(inputDate);
    System.out.println(newDate);
}

这将正确打印:

03.01.2010 21:32:27

(我在格林威治标准时间-4)

更新2:根据您的编辑,您确实得到了一个。然后,最可疑的部分是 的时区。这在您的Java环境中真的知道吗?您使用的是什么 Java 版本和操作系统版本?检查 TimeZone.getAvailableIDs()。两者之间必须有一个。ParseExceptionUTCUTC


答案 2

我在Talend中遇到了此错误。我能够毫无问题地存储从Redshift创建的S3 CSV文件。当我尝试将相同的S3 CSV文件加载到Amazon RDS MySQL数据库中时发生错误。我尝试了默认的时间戳Talend时间戳格式,但它们在加载到MySQL时会抛出异常:无法解析的日期。

这个从接受的答案帮助我解决了这个问题:

顺便说一句,“不可解析的日期”异常在这里只能由SimpleDateFormat#parse()引发。这意味着 inputDate 不在预期的模式“y-MM-dd HH:mm:ss z”中。您可能需要修改模式以匹配 inputDate 的实际模式

我的解决方案的关键是更改 Talend 架构。Talend将时间戳字段设置为“date”,所以我将其更改为“时间戳”,然后我将“yyyy-MM-dd HH:mm:ss z”插入格式字符串列查看屏幕截图这里 talend 架构

我在12小时和24小时时间戳翻译方面遇到了其他问题,直到我在时间戳字符串的末尾添加了“z”。