Пример данных
df <- data.frame(loc.id = rep(1:5, each = 6), day = sample(1:365,30),
ref.day1 = rep(c(20,30,50,80,90), each = 6),
ref.day2 = rep(c(10,28,33,49,67), each = 6),
ref.day3 = rep(c(31,49,65,55,42), each = 6))
Для каждого loc.id, если я хочу сохранить дни>> = ref.day1, я делаю это:
df %>% group_by(loc.id) %>% dplyr::filter(day >= ref.day1)
Я хочучтобы сделать 3 фрейма данных, каждый из которых строки фильтруются по ref.day1
, ref.day2
, ref.day3
соответственно
Я попытался это:
col.names <- c("ref.day1","ref.day2","ref.day3")
temp.list <- list()
for(cl in seq_along(col.names)){
col.sub <- col.names[cl]
columns <- c("loc.id","day",col.sub)
df.sub <- df[,columns]
temp.dat <- df.sub %>% group_by(loc.id) %>% dplyr::filter(day >= paste0(col.sub)) # this line does not work
temp.list[[cl]] <- temp.dat
}
final.dat <- rbindlist(temp.list)
Мне было интересно, как обратиться кстолбцы по именам и вставьте функцию в dplyr, чтобы отфильтровать его.