Calulcate在一列时间戳上使用difftime运行时间差

Nic*_*sen 0 r difftime

如何计算两个连续时间戳行的时间差(以分钟为单位),并将结果添加到新列中.

我试过这个:

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)

Bil*_*ney 5

您与[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)

这段代码的作用是:

  1. 设置一个数据帧,这样你将保持的长度timestampsmins相同的.
  2. 在该数据框架中,输入您拥有的时间戳以及您还没有任何分钟的事实(即NA).
  3. 选择除时间戳的第一个元素之外的所有元素 mytimes$timestamps[-1]
  4. 选择除时间戳的最后一个元素之外的所有元素 mytimes$timestamps[-nrow(mytimes)]
  5. 减去它们difftime(因为它们格式正确,你首先不必使它们成为POSIXct对象),单位为分钟.units="mins"
  6. 把NA放在前面,因为你的差异比行数少一点 c(NA, ...)
  7. 将所有内容放回原始数据框的mins列 mytimes$mins <-