原文转载:http://bosschen.iteye.com/blog/1409179
关键字: simpledateformat24小时 格式串
G | Era 标志符 | Text | AD |
y | 年 | Year | 1996; 96 |
M | 年中的月份 | Month | July; Jul; 07 |
w | 年中的周数 | Number | 27 |
W | 月份中的周数 | Number | 2 |
D | 年中的天数 | Number | 189 |
d | 月份中的天数 | Number | 10 |
F | 月份中的星期 | Number | 2 |
E | 星期中的天数 | Text | Tuesday; Tue |
a | Am/pm 标记 | Text | PM |
H | 一天中的小时数(0-23) | Number | 0 |
k | 一天中的小时数(1-24) | Number | 24 |
K | am/pm 中的小时数(0-11) | Number | 0 |
h | am/pm 中的小时数(1-12) | Number | 12 |
m | 小时中的分钟数 | Number | 30 |
s | 分钟中的秒数 | Number | 55 |
S | 毫秒数 | Number | 978 |
z | 时区 | General time zone | Pacific Standard Time; PST; GMT-08:00 |
Z | 时区 | RFC 822 time zone | -0800 |
java.text.SimpleDateFormat sf = new java.text.SimpleDateFormat("yyyyMMddkkmmss");
java.util.Date date = new java.util.Date();
String time = sf.format(date);
--得到的是24小时显示。
如果把kk换成hh,则是12小时显示。
个人说明:
转载的原因,是因为被坑了。选的数据是24小时制的,存到数据库里也是24小时制的,但是拿出来显示到页面竟然自动变成了12小时制的,很奇怪。以为是电脑设置的原因,可是电脑时间可以显示24小时制的啊。后来一路dubug,终于发现是使用了SimpleDateFormat,原代码如下:
/***
* 将Timestamp类型的数据转换成字符串
* @param date
* @return 字符串类型且格式化后的日期
*/
public static String getFormatYYYYMMDDHHMMSSS(Timestamp date){
SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
return df.format(date);
}
格式化中设置的是hh,小写的,它就表示“am/pm 中的小时数(1-12)”,所以原有的24小时制的经它格式化之后就成12小时制的了。将hh改成HH或kk就成。(哎,坑死人不偿命啊!)