我想要一个函数my_lm
,如下所示:
library(rlang)
base_formula <- new_formula(lhs = quote(potato),
rhs = quote(Sepal.Width + Petal.Length))
my_lm <- function(response) {
lm(formula = update(old = base_formula, new = quote(response) ~ . ),
data = iris)
}
my_lm(response = Sepal.Length)
但是我遇到了以下错误:
Error in model.frame.default(formula = update(old = base_formula, new = enquo(response) ~ :
object is not a matrix
我怀疑我在滥用rlang
,但我似乎无法弄清楚引用、取消引用和公式化的组合可以解决这个问题。
编辑:所需的输出就像我跑了:
lm(formula = Sepal.Length ~ Sepal.Width + Petal.Length,
数据=虹膜)
EDIT2:我还应该澄清一下,我真的对rlang
用于解决此问题的解决方案感兴趣,update
而不是使用paste
,gsub
和formula
.