猿问

如何在 Java 8(Scala)中将日期时间字符串转换为长(UNIX 纪元时间)毫秒

这个问题解决了秒的情况:如何在Java 8(Scala)中将日期时间字符串转换为长(UNIX Epoch Time)

但是,如果我想要毫秒,似乎我必须使用

def dateTimeStringToEpoch(s: String, pattern: String): Long = 
    LocalDateTime.parse(s, DateTimeFormatter.ofPattern(pattern))
      .atZone(ZoneId.ofOffset("UTC", ZoneOffset.ofHours(0)))
      .toInstant().toEpochMilli

对于我在另一个问题中详细介绍的4个问题来说,这是丑陋的(我不喜欢的主要东西是魔术字面和魔术数字)。"UTC"0

不幸的是,以下内容无法编译

def dateTimeStringToEpoch(s: String, pattern: String): Long = 
     LocalDateTime.parse(s, DateTimeFormatter.ofPattern(pattern))
                  .toEpochMilliSecond(ZoneOffset.UTC)

因为不存在toEpochMilliSecond


HUH函数
浏览 204回答 3
3回答

小怪兽爱吃肉

你能不能使用 LocalDateTime#atOffset 和 ZoneOffset#UTC?LocalDateTime.parse(s, dateTimeFormatter).atOffset(ZoneOffset.UTC).toInstant().toEpochMilli()正如@Andreas在注释中指出的那样,is-a ,因此您可以使用ZoneOffsetZoneIddef dateTimeStringToEpoch(s: String, pattern: String): Long =      LocalDateTime.parse(s, DateTimeFormatter.ofPattern(pattern))       .atZone(ZoneOffset.UTC)       .toInstant()       .toEpochMilli()

三国纷争

您可以更改此答案以返回 epoch millis,例如static long dateTimeStringToEpoch(String s, String pattern) {&nbsp; &nbsp; return DateTimeFormatter.ofPattern(pattern).withZone(ZoneOffset.UTC)&nbsp; &nbsp; &nbsp; &nbsp; .parse(s, Instant::from).toEpochMilli();}或者,如果您甚至想避免临时施工:Instantstatic long dateTimeStringToEpoch(String s, String pattern) {&nbsp; &nbsp; return DateTimeFormatter.ofPattern(pattern).withZone(ZoneOffset.UTC)&nbsp; &nbsp; &nbsp; &nbsp; .parse(s, ta -> ta.getLong(ChronoField.INSTANT_SECONDS)*1000&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;+ta.get(ChronoField.MILLI_OF_SECOND));}请注意,两者在这里都是可重用的组件,例如,您可以DateTimeFormatter.ofPattern(pattern).withZone(ZoneOffset.UTC)ta -> ta.getLong(ChronoField.INSTANT_SECONDS)*1000+ta.get(ChronoField.MILLI_OF_SECOND)static final DateTimeFormatter MY_PATTERN&nbsp; &nbsp; = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm").withZone(ZoneOffset.UTC);static final TemporalQuery<Long> EPOCH_MILLIS&nbsp; &nbsp; = ta -> ta.getLong(ChronoField.INSTANT_SECONDS)*1000+ta.get(ChronoField.MILLI_OF_SECOND);和long millis = MY_PATTERN.parse("2018-07-21 18:30", EPOCH_MILLIS);问题是,您希望在应用程序中出现多少个不同的格式字符串。通常,它不会像您必须解析的格式化日期那样频繁地更改。创建从格式字符串到预准备的缓存映射可能会有所帮助。无论如何,lambda 表达式是单例。DateTimeFormatter

墨色风雨

在使用 UNIX Epoch 时,我建议使用它为纪元表示而设计的,并且默认会考虑,因为它是标准的一部分。java.time.InstantUTCimport java.time.Instantobject InstantFormat extends App {&nbsp; //Instant.parse uses DateTimeFormatter.ISO_INSTANT&nbsp; println(Instant.parse("2019-03-12T15:15:13.147Z"))&nbsp; println(Instant.parse("2019-03-12T15:15:13Z"))&nbsp; println(Instant.parse("2019-03-12T15:15:13Z").toEpochMilli)&nbsp; println(Instant.parse("2019-03-12T15:15:13Z").getEpochSecond)&nbsp; println(Instant.ofEpochMilli(1552403713147L))&nbsp; println(Instant.ofEpochSecond(1552403713L))}输出2019-03-12T15:15:13.147Z2019-03-12T15:15:13Z155240371300015524037132019-03-12T15:15:13.147Z2019-03-12T15:15:13Z
随时随地看视频慕课网APP

相关分类

Java
我要回答