时间转换中是否缺少某些内容?很简单的例子:
library(lubridate)
time <- "2019-01-14 10:58:23.438000"
op <- options(digits.secs=6)
ymd_hms(time, tz = "Europe/Helsinki")
[1] "2019-01-14 10:58:23.437 EET"
ymd_hms(time)
[1] "2019-01-14 10:58:23.437 UTC"
为什么毫秒在这里差一秒?似乎不是四舍五入的问题吗?
这似乎可行:
time <- "2019-01-14 10:58:23.123456"
op <- options(digits.secs=6)
ymd_hms(time)
[1] "2019-01-14 10:58:23.123456 UTC"
SessionInfo
sessionInfo()
R version 3.5.1 (2018-07-02)
Platform: x86_64-w64-mingw32/x64 (64-bit)
Running under: Windows >= 8 x64 (build 9200)
Matrix products: default
locale:
[1] LC_COLLATE=Finnish_Finland.1252 LC_CTYPE=Finnish_Finland.1252 LC_MONETARY=Finnish_Finland.1252 LC_NUMERIC=C
[5] LC_TIME=Finnish_Finland.1252
attached base packages:
[1] stats graphics grDevices utils datasets methods base
other attached packages:
[1] lubridate_1.7.4
loaded via a namespace (and not attached):
[1] compiler_3.5.1 magrittr_1.5 tools_3.5.1 yaml_2.2.0 Rcpp_1.0.0 stringi_1.2.4 stringr_1.3.1
答案 0 :(得分:1)
编辑:此答案Milliseconds in POSIXct Class解决了POSIXct
发生的情况
(请注意,您会舍入错误,并且R的日期时间格式始终向下舍入,因此,如果显示的小数位数较少,则有时看起来您已经损失了毫秒。)
ymd_hms
和as.POSIXct
似乎都存在问题。
如果我直接调用strptime
或使用as.POSIXlt
,则毫秒可以正确解析:
strptime(time, "%Y-%m-%d %H:%M:%OS", tz = "Europe/Helsinki")
as.POSIXlt(time, "%Y-%m-%d %H:%M:%OS", tz = "Europe/Helsinki")
这些选项中的任何一个都可以解决您的问题。
"2019-01-14 10:58:23.438 EET"
POSIXlt
和POSIXct
的行为不同:
as.POSIXlt(time, "%Y-%m-%d %H:%M:%OS", tz = "Europe/Helsinki") %>%
format(., "%Y-%m-%d %H:%M:%OS6")
[1] "2019-01-14 10:58:23.438000"
as.POSIXct(time, "%Y-%m-%d %H:%M:%OS", tz = "Europe/Helsinki") %>%
format(., "%Y-%m-%d %H:%M:%OS6")
[1] "2019-01-14 10:58:23.437999"