Эта проблема часто возникает, когда я импортирую необработанные данные из регистраторов данных.Регистратор температуры настроен на запись температуры каждые десять минут, а отдельный регистратор газа настроен на запись газа, использованного за последние десять минут.Я хочу объединить данные из этих двух регистраторов в один фрейм данных для построения графиков и анализа, но времена не совсем совпадают.Я хочу иметь одну строку в кадре данных для каждого десятиминутного периода, с указанием даты и времени начала периода времени.
Данные регистратора температуры выглядят следующим образом:
datetime temperature
2010-09-30 06:58:53 78.996
2010-09-30 07:08:53 78.645
2010-09-30 07:18:53 78.514
2010-09-30 07:28:53 79.173
2010-09-30 07:38:53 78.602
Данные регистратора газа выглядят следующим образом:
datetime gas
2010-09-30 13:45:00 0
2010-09-30 13:55:00 1
2010-09-30 14:05:00 0
2010-09-30 14:15:00 4
2010-09-30 14:25:00 2
Я хочу объединить два фрейма данных с интервалом в десять минут, чтобы объединенные данные выглядели так:
datetime temperature gas
2010-09-30 13:40:00 NA 0
2010-09-30 13:50:00 78.996 1
2010-09-30 14:00:00 78.645 0
2010-09-30 14:10:00 78.514 4
2010-09-30 14:20:00 79.173 2
2010-09-30 07:38:53 78.602 NA
Вот некоторый код для получения этих двух фреймов данных:
temps <- data.frame(datetime=c("2010-09-30 06:58:53",
"2010-09-30 07:08:53","2010-09-30 07:18:53",
"2010-09-30 07:28:53","2010-09-30 07:38:53"),
temperature=c(78.996,78.645,78.514,79.173,78.602),
stringsAsFactors=FALSE)
temps$datetime <- strptime(temps$datetime, format="%Y-%m-%d %H:%M:%S")
gas <- data.frame(datetime=c("2010-09-30 13:45:00",
"2010-09-30 13:55:00","2010-09-30 14:05:00",
"2010-09-30 14:15:00","2010-09-30 14:25:00"),
gas=c(0,1,0,4,2),stringsAsFactors=FALSE)
gas$datetime <- strptime(temps$datetime, format="%Y-%m-%d %H:%M:%S")