java中,Date如何格式化为“yyyy-MM-dd”格式Date,并可按需求格式输出!(java.util.Date)
/***把日期格式化**@paramdate*@paramformat*@return*/publicstaticDateformatDate(Datedate,Stri...
/**
* 把日期格式化
*
* @param date
* @param format
* @return
*/
public static Date formatDate(Date date, String format) {
String dateStr = format(date, format);
Date dateFormat = null;
SimpleDateFormat formater = new SimpleDateFormat(format);
try {
formater.setLenient(false);
dateFormat = formater.parse(dateStr);
} catch (Exception e) {
dateFormat = null;
e.printStackTrace();
logger.error("日期转化出错");
}
return dateFormat;
}
其中date = "2018-01-01 13:49:45";format = "yyyy-MM-dd";
输出得到的结果dateFormat = "2018-01-01 00:00:00";
实际期望结果:dateFormat = "2018-01-01";
PS:使用java.sql.Date 处理dateFormat可以实现该需求!
java.sql.Date sqlDate = new java.sql.Date(dateFormat);
返回的sqlDate是正确格式,但需要承接该结果的类型也要是java.sql.Date的!
能否只使用java.util.Date就实现该需求?遇到很多次了,每次只能迂回着实现,太费事,求大神指教_(´ཀ`」∠)_加班 展开
* 把日期格式化
*
* @param date
* @param format
* @return
*/
public static Date formatDate(Date date, String format) {
String dateStr = format(date, format);
Date dateFormat = null;
SimpleDateFormat formater = new SimpleDateFormat(format);
try {
formater.setLenient(false);
dateFormat = formater.parse(dateStr);
} catch (Exception e) {
dateFormat = null;
e.printStackTrace();
logger.error("日期转化出错");
}
return dateFormat;
}
其中date = "2018-01-01 13:49:45";format = "yyyy-MM-dd";
输出得到的结果dateFormat = "2018-01-01 00:00:00";
实际期望结果:dateFormat = "2018-01-01";
PS:使用java.sql.Date 处理dateFormat可以实现该需求!
java.sql.Date sqlDate = new java.sql.Date(dateFormat);
返回的sqlDate是正确格式,但需要承接该结果的类型也要是java.sql.Date的!
能否只使用java.util.Date就实现该需求?遇到很多次了,每次只能迂回着实现,太费事,求大神指教_(´ཀ`」∠)_加班 展开
2个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询