以(yyyy-MM-dd)格式解析字符串日期

我有“2013-09-18”forms的字符串。 我想将它转换为java.util.Date。 我这样做

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Date convertedCurrentDate = sdf.parse(currentDateText); 

convertedCurrentDate将于’Wed Sep 18 00:00:00 IST 2013′

我希望我的输出格式为’2013-09-18′

小时,分钟和秒不应该来,它应该是yyyy-MM-dd的forms。

您可能需要按如下方式format输出。

  SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); Date convertedCurrentDate = sdf.parse("2013-09-18"); String date=sdf.format(convertedCurrentDate ); System.out.println(date); 

使用

  String convertedCurrentDate =sdf.format(sdf.parse("2013-09-18")); 

出局:

  2013-09-18 

TL;博士

 LocalDate.parse( "2013-09-18" ) 

……而且……

 myLocalDate.toString() // Example: 2013-09-18 

java.time

问题和其他答案已过时。 麻烦的旧遗留日期时间类现在被java.time类取代。

ISO 8601

您的输入字符串符合标准ISO 8601格式YYYY-MM-DD。 在解析和生成日期时间值的字符串表示时,java.time类默认使用ISO 8601格式。 因此无需指定格式化模式。

LocalDate

LocalDate类表示没有时间且没有时区的仅日期值。

 LocalDate ld = LocalDate.parse( "2013-09-18" ); 

关于java.time

java.time框架内置于Java 8及更高版本中。 这些类取代了麻烦的旧遗留日期时间类,如java.util.DateCalendarSimpleDateFormat

现在处于维护模式的Joda-Time项目建议迁移到java.time类。

要了解更多信息,请参阅Oracle教程 。 并搜索Stack Overflow以获取许多示例和解释。 规范是JSR 310 。

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

从哪里获取java.time类?

  • Java SE 8Java SE 9Java SE 10及更高版本
    • 内置。
    • 带有捆绑实现的标准Java API的一部分。
    • Java 9增加了一些小function和修复。
  • Java SE 6Java SE 7
    • 许多java.timefunction都被反向移植到ThreeTen-Backport中的 Java 6和7。
  • Android的
    • 更高版本的Android捆绑java.time类的实现。
    • 对于早期的Android(<26), ThreeTenABP项目采用ThreeTen-Backport (如上所述)。 请参见如何使用ThreeTenABP ….

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

您正在创建一个Date对象,它表示时间轴中的某个点。 这意味着它将具有正确表示所需的所有部件,包括分钟和秒等。 因为您从仅包含日期的一部分的字符串初始化它,所以缺少的数据将被默认。

我假设你正在“打印”这个Date对象,但没有实际指定像解析它时那样的格式。 使用相同的SimpleDateFormat,但调用反向方法,格式(日期)为Holger建议

 DateFormat df = new SimpleDateFormat("MM/dd/yyyy"); String cunvertCurrentDate="06/09/2015"; Date date = new Date(); date = df.parse(cunvertCurrentDate); 

我将String格式转换为Date(“yyyy-MM-dd”)以保存到Mysql数据库中。

  String date ="2016-05-01"; SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); Date parsed = format.parse(date); java.sql.Date sql = new java.sql.Date(parsed.getTime()); 

sql它是我日期格式的输出