給定是一系列具有開始和結束時間以及擁有者的作業。計算不同行的列之間的difftime
Data <- data.frame(
job = c(1, 2, 3, 4, 5),
owner = c("name1", "name2", "name1", "name1", "name2"),
Start = as.POSIXct(c("2015-01-01 15:00:00", "2015-01-01 15:01:00", "2015-01-01 15:13:00", "2015-01-01 15:20:00", "2015-01-01 15:39:02"), format="%Y-%m-%d %H:%M:%S"),
End = as.POSIXct(c("2015-01-01 15:11:11", "2015-01-01 15:17:21", "2015-01-01 15:17:00", "2015-01-01 15:31:21", "2015-01-01 15:40:11"), format="%Y-%m-%d %H:%M:%S")
)
對於每一行我想計算每個所有者的作業之間的空閒時間。如何使用difftime()來計算特定行和不同列之間的時間差異?
結果應該是這個樣子:
job, owner, idletime
1, name1, NA
2, name2, NA
3, name1, 1.816667 # end of row 1 minus start of row 3
4, name1, 3.0 # end of row 3 minus start of row 4
...