Как использовать строковые переменные для создания списка переменных для ddply? - PullRequest
10 голосов
/ 24 сентября 2010

Используя пример встроенного набора данных ToothGrowth от R, это работает:

ddply(ToothGrowth, .(supp,dose), function(df) mean(df$len)) 

Но я бы хотел, чтобы факторы поднабора были переменными, что-то вроде

factor1 = 'supp'
factor2 = 'dose'
ddply(ToothGrowth, .(factor1,factor2), function(df) mean(df$len)) 

Это не работает,Как это сделать?

Я подумал, может быть, что-то вроде этого:

factorCombo = paste('.(',factor1,',',factor2,')', sep='') 
ddply(ToothGrowth, factorCombo, function(df) mean(df$len)) 

Но это тоже не работает.Я думаю, что я близко, но не уверен, как правильно это сделать.Я полагаю, что вся команда может быть помещена в строку с последующим вызовом eval () строки, но, надеюсь, есть более элегантный способ?

1 Ответ

8 голосов
/ 24 сентября 2010

Попробуйте:

x <- c("supp", "dose") 
ddply(ToothGrowth, x, function(df) mean(df$len)) 
...