R as.POSIXct 解析错误

标签 r posixct

我正在尝试解析时间字符串向量并遇到一个奇怪的错误。例如,如果我运行以下代码段,R 会按预期返回结果。

time_format="%m/%d/%Y %H:%M:%S"
t_1 = "03/13/2011 01:00:10"
as.POSIXct(t_1, format = time_format)

输出:
[1] "2011-03-13 01:00:10 EST"

但是,如果我将时间稍微更改为凌晨 2 点
t_2 = "03/13/2011 02:00:10"
as.POSIXct(t_2, format = time_format)

输出变成了:
[1] NA

我可以在 Windows 7 和 XP 上的 R 2.11.1 和 2.12.2 上重现它。有没有人遇到同样的问题?

谢谢,
德里克

最佳答案

不能 解析不存在的时间。 02:00:10 不存在,因为我们在这个星期六晚上/星期天早上有“ Spring 向前”,切换到夏令时。 R 知道这一点:

R> t_1 = "03/13/2011 01:00:10"; as.POSIXct(t_1, format = time_format)
[1] "2011-03-13 01:00:10 CST"
R> t_2 = "03/13/2011 02:00:10"; as.POSIXct(t_2, format = time_format)
[1] "2011-03-13 01:00:10 CST"
R> t_3 = "03/13/2011 03:00:10"; as.POSIXct(t_3, format = time_format)
[1] "2011-03-13 03:00:10 CDT"
R> 

在 Linux 上,我的时区库似乎可以应付——减去一个小时后,02:00:10 变为 01:00:10。

关于R as.POSIXct 解析错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5302893/

相关文章:

r - 传递空省略号参数时的不同行为

r - 如何传递列变量来应用函数?

r - R's lubridate 中的独家时间间隔

r - 使用 R 中的稀疏矩阵从向量中提取元素,而不转换为稠密矩阵

r - 快速融化的数据表操作

r - 如何判断一个数是否为正自然数?

R sqldf 无法识别 posixct

r - 根据最近的时间戳在 R 中加入两个数据帧

regex - 如何最有效地将 "01 Jan 2014"的字符串转换为 POSIXct,即 "2014-01-01"yyyy-mm-dd

R - 使用 HHMMSS 格式将日期和时间字段转换为 POSIXct