7

我想知道在使用带有 purrr 的管道操作时如何获取列表名称或组名称作为标志。例如:我想使用每个列表名称的动态参数传递给 ggsave 函数。

require(purrr)
require(ggplot2)
lst=list(a1=data.frame(x=1:10,y=2:11),a2=data.frame(x=1:10,y=-1*2:11))
df=rbind(transform(lst[[1]],id="a1"),transform(lst[[2]],id="a2"))
lst %>% map(~ggsave(plot=qplot(data=.,x="x",y="y",geom="line"),file=paste(listname(.),".png")))
df %>% slice_rows("id") %>%
  by_slice(~ggsave(plot=qplot(data=.,x="x",y="y",geom="line"),file=paste("slicename(.)",".png")))

slicename(.) 应该类似于 unique(.[["id"]]),但在使用 slice_rows 时它不起作用。

4

2 回答 2

6

值得一提的是,使用purrr::walk2one 可以避免使用lstnames(lst)元素创建新列表:

lst=list(a1=data.frame(x=1:10,y=2:11),a2=data.frame(x=1:10,y=-1*2:11))

purrr::walk2(
  lst,
  names(lst),
  ~ ggsave(plot=qplot(data=.x,x=x,y=y,geom="line"),filename=paste(.y,".png"))
)

2017-08-30 更新:在 0.2.3 中引入了一个新的“索引”地图函数系列,purrr它提供了一个简写walk2(lst, names(lst))

lst=list(a1=data.frame(x=1:10,y=2:11),a2=data.frame(x=1:10,y=-1*2:11))

purrr::iwalk(
  lst,
  ~ ggsave(plot=qplot(data=.x,x=x,y=y,geom="line"),filename=paste(.y,".png"))
)
于 2016-06-14T16:04:27.567 回答
5

listname并且slicename不是函数,purrr并且names在与函数一起使用时似乎不会返回列表元素名称purrr。此外,您可能想要使用walk函数族,而不是map因为by_slice您调用函数是为了它的副作用,而不是为了返回的对象。

因此,作为一种解决方法,您可以尝试

   lst=list(a1=data.frame(x=1:10,y=2:11),a2=data.frame(x=1:10,y=-1*2:11))

   list(lst, names(lst)) %>% 
        pwalk( ~ ggsave(plot=qplot(data=.x,x=x,y=y,geom="line"),filename=paste(.y,".png")) )

添加

如果您从数据框开始,您可以使用

df %>% split(.$id) %>% 
       list( names(.)) %>% 
       pwalk( ~ ggsave(plot=qplot(data=.x, x=x, y=y, geom="line"), filename=paste(.y,".png")))
于 2016-01-17T20:29:26.853 回答