有没有办法`管理列表'?

时间:2015-11-06 19:51:38

标签: r ggplot2 dplyr magrittr

我从未真正开发的ggplot2包中的一个非常酷的功能是在图中添加图层列表。有趣的是,我可以将一个图层列表作为参数传递给函数,并将它们添加到图中。然后我可以获得所需的情节外观,而不必从函数中返回图表(这是否是一个好主意是另一回事,但它是可能的。)

library(ggplot2)
x <- ggplot(mtcars,
            aes(x = qsec,
                y = mpg)) 

layers <- list(geom_point(),
               geom_line(),
               xlab("Quarter Mile Time"),
               ylab("Fuel Efficiency"))

x + layers

有没有办法用管道做到这一点?类似于:

#* Obviously isn't going to work
library(dplyr)
action <- list(group_by(am, gear),
               summarise(mean = mean(mpg),
                         sd = sd(mpg)))

mtcars %>% action

1 个答案:

答案 0 :(得分:16)

要构建一系列magrittr步骤,请从.

开始
action = . %>% group_by(am, gear) %>% summarise(mean = mean(mpg), sd = sd(mpg))

然后它可以像OP中想象的那样使用:

mtcars %>% action

list类似,我们可以通过子集查看每个步骤:

action[[1]]
# function (.) 
# group_by(., am, gear)

要查看所有步骤,请使用functions(action)或只输入名称:

action
# Functional sequence with the following components:
# 
#  1. group_by(., am, gear)
#  2. summarise(., mean = mean(mpg), sd = sd(mpg))
# 
# Use 'functions' to extract the individual functions.