如何计算两个连续时间戳行的时间差(以分钟为单位),并将结果添加到新列中.
我试过这个:
data$hours <- as.numeric(floor(difftime(timestamps(data), (timestamps(data)[1]), units="mins")))
Run Code Online (Sandbox Code Playgroud)
但只能从零时间开始获得差异.
添加了我想要添加的'mins'列的示例数据
timestamps mins
2013-06-23 00:00:00 NA
2013-06-23 01:00:00 60
2013-06-23 02:00:00 60
2013-06-23 04:00:00 120
Run Code Online (Sandbox Code Playgroud)
您与[1]一起使用的代码始终引用时间戳向量的第一个元素.
要做你想做的事,你想看除除第一个元素之外的所有元素,除了最后一个元素.
mytimes <- data.frame(timestamps=c("2013-06-23 00:00:00",
"2013-06-23 01:00:00",
"2013-06-23 02:00:00",
"2013-06-23 04:00:00"),
mins=NA)
mytimes$mins <- c(NA, difftime(mytimes$timestamps[-1],
mytimes$timestamps[-nrow(mytimes)],
units="mins"))
Run Code Online (Sandbox Code Playgroud)
这段代码的作用是:
timestamps和mins相同的.NA).mytimes$timestamps[-1]mytimes$timestamps[-nrow(mytimes)]difftime(因为它们格式正确,你首先不必使它们成为POSIXct对象),单位为分钟.units="mins"c(NA, ...)mytimes$mins <-