我的时间戳为29-NOV-11 06.05.41.831000000 AM
使用SimpleDateFormat,我无法真正提取毫秒(.831000000).... 831是毫秒(我不知道为什么那些000000.但那来自不同的来源。无法控制。)
答案 0 :(得分:2)
额外的数字是纳秒。您不能在SimpleDateFormat或标准库中包含这些。在你的情况下最简单的做法是在解析日期/时间之前删除它们。
答案 1 :(得分:1)
使用 UTC 的时区偏移量将日期时间字符串解析为 OffsetDateTime
,并将结果转换为 Instant
。
您可以使用 Instant#toEpochMilli
将 Instant
转换为毫秒。
演示:
import java.time.Instant;
import java.time.OffsetDateTime;
import java.time.ZoneOffset;
import java.time.format.DateTimeFormatter;
import java.time.format.DateTimeFormatterBuilder;
import java.util.Locale;
public class Main {
public static void main(String[] args) {
DateTimeFormatter dtf = new DateTimeFormatterBuilder()
.parseCaseInsensitive()
.appendPattern("d-MMM-uu h.m.s.n a")
.toFormatter(Locale.ENGLISH)
.withZone(ZoneOffset.UTC);
OffsetDateTime odt = OffsetDateTime.parse("29-NOV-11 06.05.41.831000000 AM", dtf);
Instant instant = odt.toInstant();
long millis = instant.toEpochMilli();
System.out.println(millis);
}
}
输出:
1322546741831
从 modern date-time API 中了解有关 Trail: Date Time* 的更多信息。
* 出于任何原因,如果您必须坚持使用 Java 6 或 Java 7,您可以使用 ThreeTen-Backport,它将大部分 java.time 功能向后移植到 Java 6 & 7. 如果您正在为 Android 项目工作并且您的 Android API 级别仍然不符合 Java-8,请检查 Java 8+ APIs available through desugaring 和 How to use ThreeTenABP in Android Project。
答案 2 :(得分:0)
如果时间戳由字符串表示,则可以使用正则表达式来解析额外的零。
答案 3 :(得分:0)
一个有效的工作解决方案......对于这个相当严格的正则表达式,如你所见,这是非常冗长的。
String input = "29-NOV-11 06.05.41.831000000 AM";
input = input
.replaceFirst(
"(\\d+-\\w+-\\d+\\s\\d+\\.\\d+\\.\\d+\\.\\d{3})\\d{6}(\\s(\\w+))",
"$1$2");
try {
SimpleDateFormat sdf = new SimpleDateFormat(
"dd-MMM-yy HH.mm.ss.SSS aa");
Date date = sdf.parse(input);
System.out.println(sdf.format(date));
} catch (ParseException e) {
e.printStackTrace();
}
如果字符串总是固定宽度,你可以使用substr,你认为正则表达式有点过分。
input = input.substring(0, 22) + input.substring(28, 31);