我有一个命名的数据列表和一个要应用于数据的自定义函数:
#Some example data
d.list <- list(a = c(1,2,3), b = c(4,5,6), c = c(7,8,9))
#A simple function to process some data, write an output graph, and return an output
myfun <- function(data, f.name) {
y <- list()
y[1] <- data[1] + data[2] + data[3]
y[2] <- data[3] - data[1]/ data[2]
y[3] <- data[2] * data[3] - data[1]
svg(filename = f.name, width = 7, height = 5, pointsize = 12)
plot.new()
plot(data, y)
dev.off()
return(y)
}
我现在想使用它在我的列表上迭代sapply
并为每次迭代获取保存的图像文件,文件名设置为列表元素名称(例如上例中的 a.svg、b.svg、c.svg),以及包含计算结果的数据框。当我运行这个时:
#Iterate over the example data using sapply
res <- t(sapply(d.list, function(x) myfun(data=x,
f.name=paste(names(d.list), ".svg", sep = ""))))
我得到了预期的数据框:
[,1] [,2] [,3]
a 6 2.500 5
b 15 5.200 26
c 24 8.125 65
但我最终在目标目录中只得到一个文件:“a.svg”
如何将列表元素名称作为参数正确传递给我正在调用的函数sapply
?