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

时间:2013-09-18 13:02:43

标签: java date parsing

我的表格中有一个字符串" 2013-09-18"。我想将其转换为java.util.Date。 我这样做

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

convertedCurrentDate即将于9月18日星期三00:00:00 IST 2013'

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

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

5 个答案:

答案 0 :(得分:28)

您可能需要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

答案 1 :(得分:10)

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及更高版本中。这些类取代了麻烦的旧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

答案 2 :(得分:6)

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

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

答案 3 :(得分:2)

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

答案 4 :(得分:1)

我将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它是我日期格式的输出