我正在尝试使用SimpleDateFormat
模式来解析和格式化JDBC时间戳,特别是以下格式的日期yyyy-mm-dd hh:mm:ss.fffffffff
,其中ffffffffff
表示纳秒。
不幸的是,new SimpleDateFormat("yyyy-MM-dd-HH.mm.ss.SSS000000")
不起作用,引发以下异常:
java.text.ParseException: Format.parseObject(String) failed
SimpleDateFormat有可能做到这一点吗?或者我必须创建java.text.DateFormat的自定义子类来处理这种情况请注意这不是关于如何在Java中解析yyyy-mm-dd hh:mm:ss.fffffffff
字符串的问题,我感兴趣的是一种声明性方法,即不需要对输入字符串进行额外修改的SimpleDateFormat模式。
示例:
我期望输入2012-02-05 17:00:34.427000000
解析为java.util.Date,其中毫秒部分为427
。
以下是我迄今为止尝试过的格式列表,由于各种原因,它们都失败了:
new SimpleDateFormat("yyyy-MM-dd-HH.mm.ss.SSS000000")
-java.text.ParseException: Format.parseObject(String) failed
new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSSSSSSSS", Locale.US)
和new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS", Locale.US)
-都被解析为2月10日星期五15:37:14,而不是预期的(2月5日星期日17:00:34)。(427000000的纳秒部分被视为毫秒,即使只指定了SSS)
我知道这是一个迟来的答案,但我一直在研究一个类似的问题,我遇到了这个问题。
这里的问题是SimpleDateFormat
期望的是java.util.Date
,它没有纳秒字段。因此,它不处理这种情况。java.sql.Timestamp文档说它是java.util.Date
和一个纳秒字段的组合。秒的日期/时间值存储在对象的date部分。这意味着可以忽略剩余的毫秒,而使用纳秒字段。在我看来,这是一个糟糕的设计,因为java.sql.Timestamp
是java.util.Date
的直接子类。
无论如何,为了回答这个问题,我认为不可能在不附加到SimpleDateFormat
生成的字符串的情况下以纳秒打印时间戳。
这里有一种方法:
Timestamp timestamp = new Timestamp(System.currentTimeMillis());
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd-HH.mm.ss.");
format.setTimeZone(TimeZone.getDefault()); // Set the TimeZone to whatever you are expecting.
System.out.println(format.format(timestamp) + String.format("%09d", timestamp.getNanos());
编辑:
为纳秒字符串值添加了填充。
EDIT:既然您给了我们一个数据样本,它就相当简单了:
"yyyy-MM-dd HH:mm:ss.SSS"
这肯定会解析你给出的值。您可能还想显式指定Locale.US
,这样它就不会尝试使用不同的分隔符。。。
编辑:拖尾数据超过毫秒会导致问题。然而,数据的早期部分是固定长度的(我相信是23个字符),所以你应该能够写:
Date date = format.parse(text.substring(0, 23));
RFC3339的日期模式的格式为:
yyyy-MM-dd'T'HH:mm:ss.SSS'Z'
除非您有来自资源提供程序的不同日期格式。"
如果你有分数秒:
yyyy-MM-dd'T'HH:mm:ss.SSSSSS'Z'
编辑:根据你的例子,我解析你的字符串的格式是:
DateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSSSSSSSS");