从String解析为Date会抛出Unparsable Date Error

时间:2018-05-24 16:23:38

标签: java date

我有一个名为data的变量,它具有今天的格式:Thu May 24 13:14:41 BRT 2018。然后我将其格式化为MySQL的日期类型格式,即yyyy-MM-dd。这段代码就是这样做的:

String dataFormatada = new SimpleDateFormat("yyyy-MM-dd").format(data);

我想要做的是将其恢复为日期类型。我尝试了一些事情,但他们没有工作。主要的解决方案是按照另一个Stack Overflow's questioin中所描述的那样做,并且通过一点点模型,我得到了我想要的东西:

String target = "Thu Sep 28 20:29:30 JST 2000";
DateFormat df = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);
Date result =  df.parse(target);  
System.out.println(result);

但是当我在尝试解析时遇到此错误时,它无法正常工作:

java.text.ParseException: Unparseable date: "Thu Sep 28 20:29:30 JST 2000"

所以我不能只重新格式化data变量,我不能将dataFormatada带回日期格式。如何将dataFormatada带到格式为yyyy-MM-dd的日期类型?

3 个答案:

答案 0 :(得分:2)

您的目标字符串格式为EEE MMM dd HH:mm:ss zzz yyyy格式。因此,您需要使用EEE MMM dd HH:mm:ss zzz yyyy作为模式而不是yyyy-MM-dd

    String target = "Thu Sep 28 20:29:30 JST 2000";
    DateFormat df = new SimpleDateFormat("EEE MMM dd HH:mm:ss zzz yyyy", Locale.ENGLISH);
    Date result =  df.parse(target);  
    System.out.println(result);

如果您想将Date对象转换为yyyy-MM-dd,请使用以下代码。

    DateFormat dfDateToStr = new SimpleDateFormat("yyyy-MM-dd", Locale.ENGLISH);
    String formattedDate  = dfDateToStr.format(result);
    System.out.println("Formatted Date String : "+formattedDate);

答案 1 :(得分:2)

您需要两个格式化程序,一个用于将原始字符串解析为Date对象,一个用于将其格式化为所需的字符串:

public static void main(String[] args) throws Exception {
    String target = "Thu Sep 28 20:29:30 JST 2000";
    DateFormat parser = new SimpleDateFormat("EEE MMM dd kk:mm:ss z yyyy", Locale.ENGLISH);
    Date result = parser.parse(target);
    System.out.println(result);

    SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
    String dataFormatada = format.format(result);
}

答案 2 :(得分:1)

TL;博士

对于SQL标准DATE列,请将java.time.LocalDate类与JDBC 4.2或更高版本一起使用。

myPreparedStatement.setObject(
    … ,
    ZonedDateTime.parse(  // Represent a moment in a particular time zone.
        "Thu May 24 13:14:41 BRT 2018".replace( "BRT" , "Europe/London" ) ,
        DateTimeFormatter.ofPattern( "EEE MMM d HH:mm:ss z uuuu" , Locale.UK )
    )
    .toLocalDate()        // Extract a date-only value, without time-of-day and without time zone.
)

ISO 8601

  

我有一个名为data的变量,今天的格式如下:Thu May 24 13:14:41 BRT 201

这是一种糟糕的格式。将日期时间值作为文本进行交换时,请仅使用标准ISO 8601格式。方便的是, java.time 类在解析/生成字符串时默认使用这些格式。

BST = ?? (巴西标准时间,英国标准时间,......)

continent/region的格式指定proper time zone name,例如America/MontrealAfrica/CasablancaPacific/Auckland。切勿使用诸如BSTIST之类的3-4字母缩写,因为它们不是真正的时区,不是标准化的,甚至不是唯一的(!)。

ZonedDateTime课程会尝试猜测预期的时区。但是你应该依赖代码中的猜测。

String input = "Thu May 24 13:14:41 BRT 2018";
DateTimeFormatter f = DateTimeFormatter.ofPattern( "EEE MMM d HH:mm:ss z uuuu" , Locale.UK );
ZonedDateTime zdt = ZonedDateTime.parse( input , f );
  

2018-05-24T13:14:41-03:00 [美国/圣保罗]

看起来 java.time Brazil Standard Time猜测你的意思是BST。如果您指的是其他区域,例如英国时间,请用适当的时区名称替换BST字符串。

指定Locale以确定(a)翻译日期名称,月份名称等的人类语言,以及(b)文化规范决定缩写,大小写,标点符号,分隔符和这样

String input = "Thu May 24 13:14:41 BRT 2018".replace( "BRT" , "Europe/London" );
DateTimeFormatter f = DateTimeFormatter.ofPattern( "EEE MMM d HH:mm:ss z uuuu" , Locale.UK );
ZonedDateTime zdt = ZonedDateTime.parse( input , f );
  

2018-05-24T13:14:41 + 01:00 [欧洲/伦敦]

LocalDate

你显然只关心约会对象。因此,提取仅限日期的对象LocalDate

LocalDate ld = zdt.toLocalDate() ;

智能对象,而不是哑字符串

不要将日期时间值与数据库交换为文本。而是使用JDBC和对象。从JDBC 4.2及更高版本开始,您可以直接与数据库交换 java.time 对象。

myPreparedStatement.setObject( … , ld ) ;

检索。

LocalDate ld = myResultSet.getObject( … , LocalDate.class ) ;

关于 java.time

java.time框架内置于Java 8及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.DateCalendar和& SimpleDateFormat

现在位于Joda-Timemaintenance mode项目建议迁移到java.time类。

要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310

您可以直接与数据库交换 java.time 对象。使用符合JDBC driver或更高版本的JDBC 4.2。不需要字符串,不需要java.sql.*类。

从哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如IntervalYearWeekYearQuartermore