将一组字符格式的日期转换为 POSIXct 对象时,我遇到了以下错误。
示例数据:
t<-c("3/11/2007 1:30", "3/11/2007 2:00", "4/11/2007 2:00")
str(t)
chr [1:3] "3/11/2007 1:30" "3/11/2007 2:00" "4/11/2007 2:00"
z<-as.POSIXct(strptime(t, format ="%m/%d/%Y %H:%M"))
z
"2007-03-11 01:30:00 MST" NA "2007-04-11 02:00:00 MDT"
str(z)
POSIXct[1:3], format: "2007-03-11 01:30:00" NA "2007-04-11 02:00:00"
我的问题是为什么 z 中的第二个日期返回 NA?我有一个数据集,其中包含 8 年的每小时数据(我从中复制了上面的日期),并且仅在 3/8 - 3/14 之间的日期且仅当小时为 02:00:00 时才会弹出此 NA 错误。
如果日期转换为 POSIXlt,我不会遇到错误,所以这是我当前的解决方法。
有什么想法吗?
最佳答案
尝试使用不使用夏令时的时区:
as.POSIXct(t, format = "%m/%d/%Y %H:%M", tz = "GMT")
## [1] "2007-03-11 01:30:00 GMT" "2007-03-11 02:00:00 GMT" "2007-04-11 02:00:00 GMT"
关于r - POSIXct 日期转换错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27624947/