Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/330.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java SimpleDataFormat-以毫秒为单位解析时间戳_Java - Fatal编程技术网

Java SimpleDataFormat-以毫秒为单位解析时间戳

Java SimpleDataFormat-以毫秒为单位解析时间戳,java,Java,我有一个服务的时间戳字符串,它有6毫秒的数字: String timestamp = "2014-09-30T15:30:00.777777"; 我是这样分析的: String format = "yyyy-MM-dd'T'HH:mm:ss.SSS"; DateFormat df = new SimpleDateFormat(format, Locale.ENGLISH); Date date = df.parse(timestamp); SimpleDateFormat df2 = ne

我有一个服务的时间戳字符串,它有6毫秒的数字:

String timestamp = "2014-09-30T15:30:00.777777";
我是这样分析的:

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));
我期待看到:

"9/30/14 3:30 PM"
但我得到的却是:

"9/30/14 3:42 PM"
提前12分钟。我尝试使用6毫秒数字的不同格式字符串:

String format = "yyyy-MM-dd'T'HH:mm:ss.SSSSSS";
timestamp = timestamp.substring(0, timestamp.length()-3);
同样的结果

我要做的似乎是手动将传入的时间戳字符串截断为3毫秒:

String format = "yyyy-MM-dd'T'HH:mm:ss.SSSSSS";
timestamp = timestamp.substring(0, timestamp.length()-3);
然后我得到了预期的结果。或者我可以使用忽略毫秒的截断格式字符串:

String format = "yyyy-MM-dd'T'HH:mm:ss";
这些解决方案正确吗?我只是误用了SimpleDataFormat吗


谢谢

7777毫秒~12分钟

下午3:30+12分钟=下午3:42

您的解析器工作正常


真正的问题是:为什么源数据会给出6位数的毫秒值?它应该被解释为777.777毫秒吗?

SimpleDateFormat认为毫秒部分是
777777
,因为它大于1000,超过1000的部分将被滚动,转换为秒和分钟。是的,在您的情况下,您应该截断输入,因为它不是毫秒,而是微秒(并且,
SimpleDataFormat
没有用于解析微秒的符号)