在 R 中,将函数向量传递给另一个函数并按名称引用每个传递的函数

In R, pass a vector of functions to a another function and refer to each passed function by name

我想将一组函数(一个列表或向量)发送到另一个函数,然后在另一个函数中我想获得我发送的那些单独函数的名称。我也想使用这些功能,但似乎工作正常。

例如:

funcA <- function(x,y){z=x+y}
funcB <- function(x,y){z=x-y}

myfunc <- function(x,y,funclist=c(funcA, funcB)){
func1 <- deparse(substitute(funclist[1]))
}

我希望 func1 等于 "funcA",但在本例中它等于 "funclist[1]"。如果我用单个函数名称替换列表,例如

myfunc <- function(x,y,funclist=funcA){
func1 <- deparse(substitute(funclist))
}

然后我得到 func1 等于 "funcA"。我认为我的缺点在于对 deparse(substitute()) 的理解,但我想知道是否还有另一种方法我忽略了。

funcA <- function(x,y){z=x+y}
funcB <- function(x,y){z=x-y}

myfunc <- function(x,y,funclist=c(funcA, funcB)){
  func.vec <- as.character(substitute(funclist))
  func1 <- func.vec[2]
  print(func1)
  func2 <- func.vec[3]
  print(func2)
}

myfunc(1,2, c(funcA,funcB))
[1] "funcA"
[1] "funcB"