as.POSIXct没有明显原因返回NA

时间:2017-10-03 17:00:34

标签: r date character posixct

我正在努力将字符串转换为具有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

我的数据框架更大,对其他随机行也是如此,但我无法确定此错误的原因以及解决问题的方法。有人可以帮忙吗? 提前致谢

1 个答案:

答案 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"