将 POSIXct 日期时间转换为日期时出现意外日期 - 时区问题?

Unexpected date when converting POSIXct date-time to Date - timezone issue?

提问人:curious_cat 提问时间:7/5/2020 最后编辑:Henrikcurious_cat 更新时间:3/4/2021 访问量:1099

问:

当我试图将日期时间强制使用 时,它似乎返回了错误的日期。POSIXctDateas.Date

我怀疑这与时区有关。我尝试了这个参数,但它没有给出预期的日期。tzas.Date

# POSIXct returns day of month 24  
data$Time[3]
# [1] "2020-03-24 00:02:00 IST"

class(data$Time[3])
# [1] "POSIXct" "POSIXt"

# coerce to Date, returns 23 
as.Date(data$Time[3])
# [1] "2020-03-23"

# try the time zone argument, without luck
as.Date(data$Time[3], tz = "IST")
# [1] "2020-03-23"
# Warning message:
# In as.POSIXlt.POSIXct(x, tz = tz) : unknown timezone 'IST' 

Sys.timezone()
# [1] "Asia/Calcutta"

任何想法,这里可能出了什么问题?

r 日期 时 posixct

评论


答:

4赞 Limey 7/6/2020 #1

线索在警告消息中。 不知道如何解释为时区,因此默认为 .假设这是印度标准时间(而不是爱尔兰标准时间),并且 IST 是 UTC+5:30,则给出了预期的结果,即使它不符合您的目的。as.Date()ISTUTCISTas.Date()

提供时区表示为与 UTC 的偏移量的日期可提供所需的结果。

as.Date("2020-03-24 00:02:00 UTC+5:30")
[1] "2020-03-24"

评论

0赞 curious_cat 7/6/2020
谢谢!它确实是印度人而不是爱尔兰人!:)我以为“IST”可以,因为第一个 posixCT 输出本身有一个 IST!显然不是!是否有可接受的时区缩写列表?我浏览了帮助文档,但找不到。
0赞 curious_cat 7/6/2020
现在的问题是我已经有一个数据框,其中包含这些日期值,例如存储在 我是否必须字符串操作这些值才能将 UTC+5:30 放入其中?或。。。。?错误是否在我使用创建数据框的位置,我是否应该以不同的方式执行此操作,以便时区在那里进行编码?data2020-03-24 00:02:00 ISTdata$timedata$Time<-as.POSIXct(data$Time,format="%m-%d-%y %I:%M %p")
5赞 G. Grothendieck 7/6/2020 #2

使用末尾注释中的设置,我们可以使用以下任何一种:

# same date as print(x) shows
as.Date(as.character(x))
## [1] "2020-03-24"

# use the time zone stored in x (or system time zone if that is "")
as.Date(x, tz = attr(x, "tzone"))
## [1] "2020-03-24"

# use system time zone
as.Date(x, tz = "")
## [1] "2020-03-24"

# use system time zone
as.Date(x, tz = Sys.timezone())
## [1] "2020-03-24"

# use indicated time zone
as.Date(x, tz = "Asia/Calcutta")
## [1] "2020-03-24"

注意

我们已经假设了这个设置。

Sys.setenv(TZ = "Asia/Calcutta")
x <- structure(1584988320, class = c("POSIXct", "POSIXt"), tzone = "")

R.version.string
## [1] "R version 4.0.2 Patched (2020-06-24 r78745)"

评论

0赞 curious_cat 7/6/2020
谢谢!输出是,是的,您发布的成语似乎有效:structure(1584988320, class = c("POSIXct", "POSIXt"), tzone = "")as.Date(data$Time[3], tz = "Asia/Calcutta")
0赞 curious_cat 7/6/2020
这也很好用! 非常感谢!as.Date(x, tz = attr(x, "tzone"))
0赞 curious_cat 7/6/2020
Sys.timezone()给出了相应的问题。[1] "Asia/Calcutta"
0赞 curious_cat 7/6/2020
第一个成语似乎失败了。 给as.Date(x, tz = check_tzones(x))check_tzones(data$Time[3])NULL
0赞 G. Grothendieck 7/6/2020
是的,我也无法让那个工作。我已经修改了答案,只包括那些有效的答案,并添加了一个注释,显示如何重现输入。