У меня есть данные о времени начала и окончания для разных заданий, сгруппированные по "владельцу":
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
...