我正在努力将字符串转换为具有as.POSIXct
函数的日期,因为它为某些行提供NA但不为其他行提供NA。这是我的一部分数据
Fecha hora Lt.s
165397 30/03/2014 0:30:00 4.76
165398 30/03/2014 0:45:00 3.66
165399 30/03/2014 1:00:00 3.84
165400 30/03/2014 1:15:00 3.84
165401 30/03/2014 1:30:00 4.38
165402 30/03/2014 1:45:00 5.14
165403 30/03/2014 2:00:00 7.22
165404 30/03/2014 2:15:00 10.77
165405 30/03/2014 2:30:00 11.79
165406 30/03/2014 2:45:00 13.12
165407 30/03/2014 3:00:00 13.12
165408 30/03/2014 3:15:00 13.12
165409 30/03/2014 3:30:00 13.12
165410 30/03/2014 3:45:00 13.66
所以我粘贴了两个第一列,然后将其转换为POSIX:
dat$datehour <- as.POSIXct(paste(dat$Fecha, dat$hora),format="%d/%m/%Y %H:%M:%S")
这就是我得到的:
Fecha hora Lt.s datehour
165397 30/03/2014 0:30:00 4.76 2014-03-30 00:30:00
165398 30/03/2014 0:45:00 3.66 2014-03-30 00:45:00
165399 30/03/2014 1:00:00 3.84 2014-03-30 01:00:00
165400 30/03/2014 1:15:00 3.84 2014-03-30 01:15:00
165401 30/03/2014 1:30:00 4.38 2014-03-30 01:30:00
165402 30/03/2014 1:45:00 5.14 2014-03-30 01:45:00
165403 30/03/2014 2:00:00 7.22 <NA>
165404 30/03/2014 2:15:00 10.77 <NA>
165405 30/03/2014 2:30:00 11.79 <NA>
165406 30/03/2014 2:45:00 13.12 <NA>
165407 30/03/2014 3:00:00 13.12 2014-03-30 03:00:00
165408 30/03/2014 3:15:00 13.12 2014-03-30 03:15:00
165409 30/03/2014 3:30:00 13.12 2014-03-30 03:30:00
165410 30/03/2014 3:45:00 13.66 2014-03-30 03:45:00
我的数据框架更大,对其他随机行也是如此,但我无法确定此错误的原因以及解决问题的方法。有人可以帮忙吗? 提前致谢
答案 0 :(得分:2)
这是由于您所在时区的夏令时。
as.POSIXct('30/03/2014 2:00:00', format='%d/%m/%Y %H:%M:%S', tz='CET')
# [1] NA
as.POSIXct('30/03/2014 2:00:00', format='%d/%m/%Y %H:%M:%S', tz='EST')
# [1] "2014-03-30 02:00:00 EST"