我想在 purrr 包的 map 函数中使用省略号参数。这是一个玩具示例:
f1<-function(x,a=NA,b=NA,prs=seq(0, 1, 0.25),SW=T){
if(SW){
res<-data.frame(name1=a,name2=b,t(quantile(x, prs, na.rm = T)), mean=mean(x, na.rm = T), sd=sd(x, na.rm = T),
NAs=length(x[is.na(x)]),n=length(x[!is.na(x)]),SWp=shapiro.test(x)$p.value,stringsAsFactors =F)
}else
{
res<-data.frame(name1=a,name2=b,t(quantile(x, prs, na.rm = T)), mean=mean(x, na.rm = T), sd=sd(x, na.rm = T),
NAs=length(x[is.na(x)]),n=length(x[!is.na(x)]),stringsAsFactors =F)
}
return(res)
}
f1(c(NA,rnorm(25),NA),SW=F)
f1(c(NA,rnorm(25),NA))
Run Code Online (Sandbox Code Playgroud)
现在我想在另一个函数 f2 中使用 f1:
f2<-function(df,...){
res<-map_df(colnames(df),~f1(df[,.],a=.,...))
return(res)
}
Run Code Online (Sandbox Code Playgroud)
其中 ... 主要用于操作 f1 函数中的 SW 和 a 或 b 参数。但是 f2 没有做我想要的,可以在这里看到
f2(iris[,-5])
f2(iris[,-5],SW=F)
Run Code Online (Sandbox Code Playgroud)
我感谢任何有关如何使用 addecuatelly ... 内地图的指南
您只需要通过map_df()调用传递省略号。否则他们无法进入内部f1()调用。
f2 <- function(df, ...){
res <- map_df(colnames(df), ~f1(df[,.], a=., ...), ...)
return(res)
}
Run Code Online (Sandbox Code Playgroud)