在sapply
和replicate
的文档中,有一个关于使用...
的警告
现在,我可以接受它,但我想了解它背后的原因。因此,我创建了这个人为设计的小示例:
innerfunction<-function(x, extrapar1=0, extrapar2=extrapar1)
{
cat("x:", x, ", xp1:", extrapar1, ", xp2:", extrapar2, "\n")
}
middlefunction<-function(x,...)
{
innerfunction(x,...)
}
outerfunction<-function(x, ...)
{
cat("Run middle function:\n")
replicate(2, middlefunction(x,...))
cat("Run inner function:\n")
replicate(2, innerfunction(x,...))
}
outerfunction(1,2,3)
outerfunction(1,extrapar1=2,3)
outerfunction(1,extrapar1=2,extrapar2=3)
也许我做了一些明显的可怕的错误,但我发现这个结果相当令人沮丧。那么谁能给我解释一下,为什么在上面对outerfunction
的所有调用中,我会得到这样的输出:
Run middle function:
x: 1 , xp1: 0 , xp2: 0
x: 1 , xp1: 0 , xp2: 0
Run inner function:
x: 1 , xp1: 0 , xp2: 0
x: 1 , xp1: 0 , xp2: 0
正如我所说的:文档似乎对此发出了警告,但我不明白为什么会这样。
发布于 2011-07-15 18:26:22
如果你看一下replicate
的代码
> replicate
function (n, expr, simplify = TRUE)
sapply(integer(n), eval.parent(substitute(function(...) expr)),
simplify = simplify)
<environment: namespace:base>
您会看到在父框架中对函数求值,其中来自调用函数的...
不再存在。
发布于 2015-04-27 09:05:35
实际上有一种方法可以做到这一点:
# Simple function:
ff <- function(a,b) print(a+b)
# This will NOT work:
testf <- function(...) {
replicate(expr = ff(...), n = 5)
}
testf(45,56) # argument "b" is missing, with no default
# This will:
testf <- function(...) {
args <- as.list(substitute(list(...)))[-1L]
replicate(expr = do.call(ff, args), n = 5)
}
testf(45,56) # 101
发布于 2018-03-07 23:11:48
另一种方法是:
g <- function(x, y) x + y
f <- function(a = 1, ...) {
arg_list <- list(...)
replicate(n = 3, expr = do.call(g, args = arg_list))
}
f(x = 1, y = 2)
https://stackoverflow.com/questions/6704536
复制相似问题