我有一个命名的数据列表和我想要应用于数据的自定义函数:
#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
在我的列表上迭代它,并为每次迭代获取一个保存的图像文件,文件名设置为列表元素名称(egasvg,b.svg,c.svg in上面的例子),以及包含计算结果的数据框。当我运行时:
#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
中调用的函数?
答案 0 :(得分:4)
如果您需要同时迭代两个向量(包括数据和文件名),请使用mapply
(或Map
)
res <- t(mapply(myfun, d.list, paste0(names(d.list), ".svg")))
答案 1 :(得分:2)
在OP的帖子中,它循环遍历&#39; d.list&#39;的每个元素,但在每个循环中调用名称(d.list),即调用向量({{ 1}})。我们需要按照&#39; d.list&#39;的c("a", "b", "c")
进行循环。通过这种方式,我们可以通过子集化获得单个names
以及names
元素。
list
如果我们使用OP的功能
lapply(names(d.list), function(x) paste0(x, ".svg"))