向 R 条形图添加垂直分隔符和标签

Add vertical separator and labels to R barplot

我有以下数据框,我从中绘制了条形图。然后,我尝试添加带有垂直线的组分隔符,并通过创建新的 x 轴在这些线之间放置标签:

Group = c("1_1", "1_2", "1_3", "2_1", "2_2", "3_1", "3_2", "3_3", "3_4")
Value = as.numeric(c("-1.23", "2.34", "0.56", "1.87", "-2.40", "5.54", "-0.98", "-2.31", "6"))
data = data.frame(Group, Value)
data
Group   Value
1_1   -1.23
1_2   2.34
1_3   0.56
2_1   1.87
2_2   -2.40
3_1   5.54
3_2   -0.98
3_3   -2.31
3_4   6.0

barplot(data$Value, xaxs="i",xaxt="n")

我正在尝试添加垂直线作为组分隔符:

。在“1_3”和“2_1”之间

。在“2_2”和“3_1”之间

并放置标签:

。原点和第一个分隔符之间的“1”

。第一和第二分隔符之间的“2”

。第二个分隔符和轴末端之间的“3”

例如,在制作散点图时,它适用于连续轴,但不适用于分类轴。 有什么方法可以根据组类别在图中的位置将组类别转换为数字吗?

我想这就是你所描述的:

barplot(data$Value, xaxs="i",xaxt="n")
abline(v = 3.7)
abline(v = 6.1)
text(3.7/2, 5.9, label = '1')
text(4.85, 5.9, label = '2')
text(8.5, 5.9, label = '3')

您可以为此目的使用 ggplot2 包:

library(ggplot2)

ggplot(data=df, aes(x=Group, y=Value)) +
  geom_bar(stat="identity") + 
  scale_x_discrete(breaks = df$Group, labels = substring(df$Group, 3, 3),
                                                                      expand=c(0.1,0.1)) +
  facet_grid(~ substring(Group, 1, 1), space="free_x", scales="free_x", switch="x") + 
  theme_bw() +
  theme(strip.placement = "outside",
        strip.background = element_rect(fill=NA,colour="grey50"),
        panel.spacing=unit(0,"cm"))

这将绘制:

如果您不需要子组 x 轴标签,只需输入 labels = NULL 而不是 labels = substring(Group, 3, 3)

数据:

  df <- structure(list(Group = structure(1:9, .Label = c("1_1", "1_2",  
  "1_3", "2_1", "2_2", "3_1", "3_2", "3_3", "3_4"), class = "factor"),  
      Value = c(-1.23, 2.34, 0.56, 1.87, -2.4, 5.54, -0.98, -2.31,  
      6)), .Names = c("Group", "Value"), row.names = c(NA, -9L), class = "data.frame")