Данные:
set.seed(42)
df1 = data.frame(
Date = seq.Date(as.Date("2018-01-01"),as.Date("2018-01-30"),1),
value = sample(1:30),
Y = sample(c("yes", "no"), 30, replace = TRUE)
)
df2 = data.frame(
Date = seq.Date(as.Date("2018-01-01"),as.Date("2018-01-30"),7)
)
Для суммы, если данные попадают в диапазон, это работает ( из моего предыдущего вопроса ):
library(data.table)
df1$start <- df1$Date
df1$end <- df1$Date
df2$start <- df2$Date
df2$end <- df2$Date + 6
setDT(df1, key = c("start", "end"))
setDT(df2, key = c("start", "end"))
d = foverlaps(df1, df2)[, list(mySum = sum(value)), by = Date ]
Как я могу сделать контрафакт?
потому что когда я пытаюсь
d = foverlaps(df1, df2)[, list(mySum = count(value)), by = Date ]
Я получаю ошибку
нет применимого метода для 'groups', примененного к объекту класса "c ('double', 'numeric')"