java中,字符串类型的时间数据怎样转换成date类型。

比如String str = "2014-3-17 14:09";输出date类型是Mon Mar 17 14:00:09 CST 2014。我想要的输出结果是date类型的2014-3-17,求解。

将字符串类型的时间转换成date类型可以使用SimpleDateFormat来转换,具体方法如下:
1、定义一个字符串类型的时间;
2、创建一个SimpleDateFormat对象并设置格式;
3、最后使用SimpleDateFormat的parse方法将String类型的时间转换成Date类型的时间。
具体代码如下:
String string = "2014-3-17";
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
Date date = null;
try {
date = dateFormat.parse(string);
System.out.println(date.toLocaleString().split(" ")[0]);//切割掉不要的时分秒数据
} catch (ParseException e) {
e.printStackTrace();
}

介绍一下SimpleDateFormat:SimpleDateFormat 是 Java 中一个非常常用的类,该类用来对日期字符串进行解析和格式化输出。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2014-03-17
ava.text.SimpleDateFormat类可以实现Date对象和字符串表示的日期信息的互相转换,
如下操作即可。
String str="2014-3-17 ";
String pattern="YYYY-MM-dd"
SimpleDateFormat sdf=new SimpleDateFormt(pattern);
Date date = sdf.parse(str);
System.out.println(data);//Mon Mar 17 00:00:00 CST 2014追问

数据库那边用的是date类型是数据,验证格式要等于2014-3-17这个格式。。客户端输入的值也是2014-3-17这种格式。我想要输出的结果是2013-3-17而不是);//Mon Mar 17 00:00:00 CST 2014

追答

你描述的问题不是很清楚,其他几个回答的人都误解,还以为是直接在java里面进行日期字符串转换。现在我也不是特别清楚你的意思到,只能大概觉得你可能是要在客户端进行验证同时对数据库进行操作,在客户端进行验证可以用javascript进行正则表达式的判断实现。如果是向数据库进行的话,在创建表的时候,使用to_data(s,format)函数即是将s字符串转换成format格式的date类型数据。

本回答被提问者采纳
第2个回答  2014-03-17
public void formateDate(){
String string = "2014-3-17 14:09";
SimpleDateFormat date = new SimpleDateFormat("yyyy-MM-dd");
Date str = null;
try {
str = date.parse(string);
} catch (ParseException e) {
e.printStackTrace();
}
System.out.println((str.toLocaleString()).split(" ")[0]);
}
第3个回答  2014-03-17
你想输出的格式,已经是转成String的了。

SimpleDateFormat fmt = new SimpleDateFormat("yyyy-MM-dd");
System.out.println(fmt.format(aDate));
第4个回答  2014-03-17
如下即可
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Date date = sdf.parse(str);
System.out.println(date);
希望能帮到你。
相似回答