3

我正在尝试提出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 的自定义子类来处理这种情况?请注意,这不是关于如何yyyy-mm-dd hh:mm:ss.fffffffff在 Java 中解析字符串的问题,我对声明性方法感兴趣,即 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)被解析为Fri Feb 10 15:37:14而不是预期的Sun Feb 05 17:00:34( 427000000的纳秒部分被视为毫秒,即使只指定了 SSS)
4

3 回答 3

5

我知道这是一个迟到的答案,但我一直在研究一个类似的问题,我遇到了这个问题。

这里的问题SimpleDateFormat是期待 a java.util.Date,它没有纳秒字段。所以,它不处理这种情况。java.sql.Timestamp文档说它是java.util.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());   

编辑:

为纳秒字符串值添加了填充。

于 2014-09-04T17:38:08.600 回答
1

编辑:现在您已经给了我们一个数据样本,它相当简单:

"yyyy-MM-dd HH:mm:ss.SSS"

这肯定会解析您给出的值。您可能还想明确指定Locale.US,这样它就不会尝试使用不同的分隔符......

编辑:超过毫秒的尾随数据会导致问题。但是,数据的早期部分是固定长度的(我相信是 23 个字符),因此您应该能够编写:

Date date = format.parse(text.substring(0, 23));
于 2012-07-31T13:01:27.030 回答
0

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");
于 2012-07-31T13:01:50.133 回答