将列表元素名称作为变量传递给lapply中的函数

时间:2016-05-07 22:17:09

标签: r sapply

我有一个命名的数据列表和我想要应用于数据的自定义函数:

#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中调用的函数?

2 个答案:

答案 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"))