1

我想通过在 ggplot 中乘以一个数字(比如 10)来缩放我的 y-var。问题是这是在一个闪亮的应用程序中,变量必须作为字符串传递,即input$variable.

如何以aes_string()与我相同的方式乘以其中一个变量aes()?这是失败时的示例:

 library(ggplot2)
 ggplot(data = subset(mtcars, cyl == 4), aes_string(x = "wt", y = "mpg")) + 
      geom_line(size = 1.5, color = "#00868B") + 
      geom_line(data = subset(mtcars, cyl == 8), aes_string(x = "wt", y = "mpg" * 10))

“mpg”* 10 中的错误:二进制运算符的非数字参数

4

2 回答 2

3

我更喜欢使用get而不是在aes_string内部调用变量ggplot2,它适用于值修改,例如:

library(ggplot2)
X <- "wt"
Y <- "mpg"
ggplot(subset(mtcars, cyl == 4), aes(get(X), get(Y))) + 
    geom_line() + 
    geom_line(data = subset(mtcars, cyl == 8), aes(y = get(Y) * 10)) +
    labs(x = X,
         y = Y)

在此处输入图像描述

PS:您不需要调用wtsecond aes,因为它与 first 中的“变量”相同aes

于 2018-06-06T17:14:59.030 回答
2

您可以使用tidyeval中介绍的方法ggplot2 v3.0.0

# install.packages("ggplot2", dependencies = TRUE)
library(ggplot2)

var1 <- "wt"
var2 <- "mpg"
multiplier <- 10

ggplot(data = subset(mtcars, cyl == 4), 
       aes(x = !! rlang::sym(var1), y = !! rlang::sym(var2))) + 
  geom_line(size = 1.5, color = "#00868B") + 
  geom_line(data = subset(mtcars, cyl == 8), 
            aes(x = !! rlang::sym(var1), y = !! rlang::sym(var2) * multiplier))

或者把所有东西都放在一个函数中

plot_select_vars <- function(var1, var2, multiplier) {

  var1 <- rlang::sym(var1)
  var2 <- rlang::sym(var2)

  ggplot(data = subset(mtcars, cyl == 4), 
         aes(x = !! var1, y = !! var2)) + 
    geom_line(size = 1.5, color = "#00868B") + 
    geom_line(data = subset(mtcars, cyl == 8), 
              aes(x = !! var1, y = !! var2 * multiplier))

}

plot_select_vars(var1, var2, multiplier)

reprex 包(v0.2.0)于 2018 年 6 月 6 日创建。

于 2018-06-06T17:22:18.163 回答