2

我有一个数据框:

x <- data.frame(id=letters[1:3],val0=1:3,val1=4:6,val2=7:9)
  id val0 val1 val2
1  a    1    4    7
2  b    2    5    8
3  c    3    6    9

我想绘制一个显示每列百分比的堆积条形图。因此,每个条形代表一行,每个条形都有长度,但有三种不同的颜色,每种颜色代表 val0、val1 和 val2 的百分比。

我试着寻找它,我得到的只是绘制堆叠图而不是堆叠比例图的方法。

谢谢。

4

1 回答 1

5

使用 ggplot2

对于ggplot2geom_bar

  1. 以长格式工作
  2. 预先计算百分比

例如

library(reshape2)
library(plyr)
# long format with column of proportions within each id
xlong <- ddply(melt(x, id.vars = 'id'), .(id), mutate, prop = value / sum(value))

ggplot(xlong, aes(x = id, y = prop, fill = variable)) + geom_bar(stat = 'identity')

在此处输入图像描述

 # note position = 'fill' would work with the value column
 ggplot(xlong, aes(x = id, y = value, fill = variable)) +
       geom_bar(stat = 'identity', position = 'fill', aes(fill = variable))

# 将返回与上面相同的图

碱基R

表格对象可以绘制为马赛克图。使用plot. 你x是(几乎)一个表格对象

# get the numeric columns as a matrix
xt <- as.matrix(x[,2:4])
# set the rownames to be the first column of x
rownames(xt) <- x[[1]]
# set the class to be a table so plot will call plot.table
class(xt) <- 'table'
plot(xt)

在此处输入图像描述

你也可以mosaicplot直接使用

mosaicplot(x[,2:4], main = 'Proportions')
于 2013-04-17T04:31:07.370 回答