Там нет функции называется «Статистика :: RNorm». Вы должны найти функцию rnorm
в «статистике» имена:
myfun <- get("rnorm", asNamespace("stats"))
myargs <- list(n=10, mean=5);
do.call(myfun, myargs);
Теперь вы, конечно, можете также перейти от имени как «статистика :: RNorm» и разделить его на часть пространства имен и имя функции:
funname <- "stats::rnorm"
fn <- strsplit(funname, "::")[[1]]
myfun <- if (length(fn)==1) fn[[1]] else get(fn[[2]], asNamespace(fn[[1]]))
myargs <- list(n=10, mean=5);
do.call(myfun, myargs);
Update Я просто хотел показать, что такой подход 2.5x быстрее, чем один из @Jeroen ...
do.call.tommy <- function(what, args, ...) {
if(is.character(what)){
fn <- strsplit(what, "::")[[1]]
what <- if(length(fn)==1) {
get(fn[[1]], envir=parent.frame(), mode="function")
} else {
get(fn[[2]], envir=asNamespace(fn[[1]]), mode="function")
}
}
do.call(what, as.list(args), ...)
}
# Test it
do.call.tommy(runif, 10)
f1 <- function(FUN) do.call.tommy(FUN, list(5))
f2 <- function() { myfun<-function(x) x; do.call.tommy(myfun, list(5)) }
f1(runif)
f1("stats::runif")
f2()
# Test the performance...
system.time(for(i in 1:1e4) do.call.jeroen("stats::runif", list(n=1, max=50))) # 1.07 secs
system.time(for(i in 1:1e4) do.call.tommy("stats::runif", list(n=1, max=50))) # 0.42 secs
как о 'do.call (stats :: rnorm, myargs)'? – kohske
@kohske - тогда это выглядит 'stats :: rnorm (n = 10, mean = 5)' еще проще :-) – Tommy
, но в этом случае вы не можете использовать список в качестве аргумента :-( – kohske