I'd like to know whether it is possible to unquote a string passed to an expression via the substitute command.
Specifically, I am using dplyr to filter and select from a data frame:
> w
subject sex response
1 1 M 19.08
2 2 M 16.46
... ... ... ...
6 6 M 23.60
7 7 M 23.96
8 8 F 22.48
9 9 F 25.79
... ... ... ...
16 16 F 26.66
The following produces the desired result:
> w %.% filter(sex == "M") %.% select(response)
response
1 19.08
2 16.46
3 22.81
4 18.62
5 18.75
6 23.60
7 23.96
But I want to do this in a more general way. Th following does not produce the required result since the string "sex" is enclosed in quotation marks.
substitute(w %.% filter(y == "M"), list(y = paste(names(w)[2])))
w %.% filter("sex" == "M")
> eval(substitute(w %.% filter(y == "M"), list(y = paste(names(w)[2]))))
[1] subject sex response
<0 rows> (or 0-length row.names)
I can always do the following:
eval(parse(text = paste("w %.% filter(", names(w)[2], " == 'M')")))
This does, however, look a little clumsy.
Are there more elegant ways of doing this? Eventually, I'd like to wrap this up in a function and make it even more general.
Any help / suggestion would be much appreciated.
Kind regards,
Stefan