Hom*_*lus 2 time datetime casting r
我在数据框中有这个专栏
> str(df[,"Saida"])
POSIXct[1:2498938], format: "2016-01-01 04:05:00" "2016-01-01 04:23:00" "2016-01-02 04:09:00" "2016-01-03 03:58:00" ...
Run Code Online (Sandbox Code Playgroud)
我想忽略事件发生时的日期,但只考虑小时,分钟和秒.我虽然很直接:
hms(df[,"Saida"])
Run Code Online (Sandbox Code Playgroud)
这就出现了
Warning message:
In .parse_hms(..., order = "HM", quiet = quiet) :
Some strings failed to parse
Run Code Online (Sandbox Code Playgroud)
不好的迹象.返回是一个充满NA的向量
-------------------------------------------------- ----------------------
你能帮我找到一个解决方案,例如:将"2016-01-01 04:05:00"转换为"04:05:00"作为时间类,所以我可以把元素之间的区别,后者
PS:这可能会有所帮助
> dput(head(df[,"Saida"]))
structure(c(1451628300, 1451629380, 1451714940, 1451800680, 1451892720,
1451973420), class = c("POSIXct", "POSIXt"), tzone = "")
Run Code Online (Sandbox Code Playgroud)
这是使用以下方法的一种方法data.table:
library(data.table)
#I named your dput(head(df[,"Saida"])) as vec
time <- as.ITime(vec)
time
#[1] "06:05:00" "06:23:00" "06:09:00" "05:58:00" "07:32:00" "05:57:00"
str(time)
#Class 'ITime' int [1:6] 21900 22980 22140 21480 27120 21420
Run Code Online (Sandbox Code Playgroud)
正如您所看到的ITime那样,您可以在以后进行任何计算.