【问题标题】:Stacked Bar-chart with count above and below x-axis?x轴上方和下方计数的堆积条形图?
【发布时间】:2020-08-30 22:27:56
【问题描述】:

我有一个包含多个类别的大型数据集,以及一个带有 YES 和 NO 值的决策列。我想绘制一个堆叠条形图,其中决定列将结果堆叠在 x 轴上方的 YES 值和 x 轴下方的 NO 值。我该怎么做?

我在下面做了一个模型来展示我想要的东西。请注意,所有类别都可以有一个 YES 和一个 NO 值。

【问题讨论】:

  • 如果您尝试过,您能否更新可重现的示例和代码?

标签: r ggplot2


【解决方案1】:

您可以使用dplyr 将“是”值转换为正数,将“否”值转换为负数,然后使用堆叠的geom_col

您还没有提供任何示例数据,所以我为以下代表做了一些补充:

set.seed(69)
df <- data.frame(Var1 = sample(LETTERS[1:6], 500, replace = TRUE, prob = 1:6),
                 Var2 = as.factor(sample(1:6, 500, replace = TRUE, prob = 6:1)),
                 YesNo = sample(c("Yes", "No"), 500, TRUE))
head(df)
#>   Var1 Var2 YesNo
#> 1    D    1   Yes
#> 2    C    3    No
#> 3    D    6   Yes
#> 4    B    3   Yes
#> 5    E    1    No
#> 6    B    1   Yes

数据操作和绘图如下所示:

library(dplyr)
library(ggplot2)

df %>% 
  group_by(Var1, Var2) %>% 
  summarize(Yes = sum(YesNo == "Yes"), No = -sum(YesNo == "No")) %>%
  ggplot(aes(x = Var2, y = Yes, fill = Var1)) + 
    geom_col(position = "stack") +
    geom_col(aes(y = No), position = "stack") +
    geom_hline(aes(yintercept = 0)) + 
    labs(y = paste("No", "Yes", sep = paste(rep(" ", 20), collapse = " ")))

reprex package (v0.3.0) 于 2020-05-14 创建

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-12-25
    • 2018-12-15
    • 2014-03-08
    • 1970-01-01
    • 2017-03-06
    相关资源
    最近更新 更多