我想相对于特定时区将 POSIXct 舍入到当天。
如果我尝试
round(as.POSIXct("2013-03-05 23:00:00 EST"), "day")
它返回
2013-03-06
这是有道理的,因为当它是 23:00:00 EST 2013-03-05 在 EST5EDT 时,它已经是 2013-03-06 在 UTC。从逻辑上讲,我想做的是:
round(as.POSIXct("2013-03-05 23:00:00 EST"), "day", tz="EST5EDT")
也就是说,“将此日期和时间四舍五入到最近的一天,相对于 EST5EDT 时区”。不幸的是,round 不接受时区参数。
最佳答案
round
一旦过了中午,就会舍入到第二天,这就是为什么我认为您看到的是 2013-03-06。我还必须明确设置 tz
对 as.POSIXct
的调用中的参数
观察:
round( as.POSIXct("2013-03-05 11:00:00" , tz = "EST" ), "day" )
[1] "2013-03-05 EST"
然后一旦过了中午:
round( as.POSIXct("2013-03-05 12:00:00" , tz = "EST" ), "day" )
[1] "2013-03-06 EST"
调用
format
将日期提取为不带 tz 参数的字符串。所以你可以在没有时区的情况下获得原始结果format( round( as.POSIXct("2013-03-05 12:00:00" , tz = "EST" ), "day" ) )
[1] "2013-03-06"
如果您想将那天的任何时间舍入到那天,也许您想要的是
trunc
?format(trunc( as.POSIXct("2013-03-05 12:00:00" , tz = "EST" ), "day" ))
[1] "2013-03-05"
关于将 POSIX 日期和时间 (posixct) 舍入为相对于时区的日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16041093/