我有一个来自服务的时间戳字符串,它有6毫秒的数字:
String timestamp = "2014-09-30T15:30:00.777777";
Run Code Online (Sandbox Code Playgroud)
我正在解析它:
String format = "yyyy-MM-dd'T'HH:mm:ss.SSS";
DateFormat df = new SimpleDateFormat(format, Locale.ENGLISH);
Date date = df.parse(timestamp);
SimpleDateFormat df2 = new SimpleDateFormat();
System.out.println(df2.format(date));
Run Code Online (Sandbox Code Playgroud)
我期待看到:
"9/30/14 3:30 PM"
Run Code Online (Sandbox Code Playgroud)
但相反,我得到:
"9/30/14 3:42 PM"
Run Code Online (Sandbox Code Playgroud)
提前十二分钟.我尝试使用6毫秒数字的不同格式字符串:
String format = "yyyy-MM-dd'T'HH:mm:ss.SSSSSS";
Run Code Online (Sandbox Code Playgroud)
结果相同.
我似乎要做的是手动将传入的时间戳字符串截断为3毫秒数字:
timestamp = timestamp.substring(0, timestamp.length()-3);
Run Code Online (Sandbox Code Playgroud)
然后我得到了预期的结果.或者我可以使用忽略毫秒的截断格式字符串:
String format = "yyyy-MM-dd'T'HH:mm:ss";
Run Code Online (Sandbox Code Playgroud)
那些正确的解决方案?我只是在滥用SimpleDateFormat吗?
谢谢
777777毫秒~12分钟
下午3:30 + 12分钟=下午3:42
您的解析器工作正常.
真正的问题:为什么您的源数据会给您6位数的毫秒值?它应该被解释为777.777毫秒?