Joe*_*Joe 0 r bar-chart ggplot2
我想将表格绘制为堆积的条形图,并用百分比标记条形。这是一个例子:
data <- matrix(c(34, 66, 22, 78), ncol = 2)
data <- as.table(data)
colnames(data) <- c("shop1", "shop2")
rownames(data) <- c("prod1", "prod2")
library(reshape2)
data_m <- melt(data, varnames = c("Product", "Shop"), id.vars = "Product")
library(scales)
library(ggplot2)
ggplot(data_m, aes(x = Shop, y = value, fill = Product)) +
geom_bar(position = "fill", stat = "identity") +
scale_y_continuous(labels = percent_format()) +
labs(x = "", y = "")
Run Code Online (Sandbox Code Playgroud)
我试图用添加标签
geom_text(data = data_m, aes(x = Shop, y = value,
label = paste0((value/100) * 100,"%")), size=4)
Run Code Online (Sandbox Code Playgroud)
编辑:随着JanLauGe的答案,我得到
现在,错误地分配了百分比。
另一句话:如果表的列总和不同,该如何处理,例如我上面的示例中假设是91和107而不是100,该怎么办?
试试这个
geom_text(data = data_m,
aes(x = Shop,
y = value / max(value),
label = paste0(value/100,"%")),
size = 4)
Run Code Online (Sandbox Code Playgroud)
问题:标签位置相对于绘图区域(0到1,1 = max(value))。
解决方案:相应地重新调整值。
编辑:这篇文章的重复。
您正在寻找的是:
ggplot(data = data_m,
aes(x = Shop,
y = value,
fill = Product,
cumulative = TRUE)) +
geom_col() +
geom_text(aes(label = paste0(value/100,"%")),
position = position_stack(vjust = 0.5)) +
theme_minimal()
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2900 次 |
| 最近记录: |