将字符格式的日期转换为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年每小时数据的数据集(我从中复制了上面的日期),这个NA错误仅在3/8 - 3/14之间的日期弹出,并且仅在小时为02:00:00时弹出。
如果日期转换为POSIXlt,我不会遇到错误,所以这是我目前的工作。
有什么想法吗?
答案 0 :(得分:2)
尝试使用不使用夏令时的时区:
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"