Возможно, вы хотите match.arg
. Например:
lmfun <- function(df, yname, xname){
y <- match.arg(deparse(substitute(yname)), names(df))
x <- match.arg(deparse(substitute(xname)), names(df))
f <- as.formula(paste0(y, "~", x))
lm.fit <- do.call("lm", list(data = quote(df), f))
coef(lm.fit)
}
lmfun(mtcars, yname = mp, dis)
# (Intercept) disp
# 29.59985476 -0.04121512
Конечно, должна быть возможность однозначно сопоставить имена:
lmfun(mtcars, yname = mp, d)
# Error in match.arg(deparse(substitute(xname)), names(df)) :
# 'arg' should be one of “mpg”, “cyl”, “disp”, “hp”, “drat”, “wt”, “qsec”,
# “vs”, “am”, “gear”, “carb”
На этот раз это не сработало, поскольку d
может быть disp
или drat
.