3

这个想法是在函数中修补对 ggplot 的调用。

这个例子:

library(dplyr)
library(ggplot2)
library(lazyeval)

df <- data.frame(A=letters[1:10], B=2:11, C=3:12))

func <- function(name, dat=df) {

  output <- dat %>%
    select_(~A,name) %>%
    arrange_(interp(~desc(var), var=as.name(name)))

  plot <- 
    ggplot(output, aes_string(x=reorder(~A,-name), y=B)) +
    geom_bar(stat='identity')

  print(plot)
  return(plot)

}

result <- func("B")

编译给出:

-name 中的错误:一元运算符的参数无效。

我试过deparsesubstitute。不确定我得到了正确的组合。有任何想法吗?

4

1 回答 1

7

在将数据传递给ggplot. 下面的代码还在ggplot调用中移动了一些列名,因为否则你总是会A针对进行绘图B,而不管name参数是什么——或者这是故意的?

function (dat, name) {
    var = as.name(name)
    reord = list(interp(~ reorder(var, -var), var = var))
    output = dat %>%
        select_(~A, name) %>% # Not actually necessary.
        arrange_(interp(~ desc(var), var = var)) %>%
        mutate_(.dots = setNames(reord, name))

    plot = ggplot(output, aes_string(x = 'A', y = name)) +
        geom_bar(stat = 'identity')

    plot(plot)
    plot
}

func(df, 'B')

我在mutate_(.dots = …)这里使用表格。查看 dplyr 的“NSE”小插图以获取有关其用法的更多信息。

于 2015-09-21T12:06:46.230 回答