我试图显示一个并排的条形图,比较两列之间每个字母等级的计数。 (彼此相邻,B彼此相邻等)
> dat = data.frame(grade1 = c('A','A','A','B','B','C'), grade2 = c('A','B','C','C','D','D'))
> dat
grade1 grade2
1 A A
2 A B
3 A C
4 B C
5 B D
6 C D
> ggplot(dat, aes(x=grade1, fill=grade2)) +
geom_bar(position=position_dodge())
我试图得到一个看起来像这样的结果,在x轴上有4个标签(A,B,C,D)。我应该使用特定的dplyr函数吗?
https://i0.wp.com/martinsbioblogg.files.wordpress.com/2014/03/means-barplot.png
答案 0 :(得分:5)
您需要以整洁的形式转换数据框。为此,你可以使用
tidyr
包函数gather
。为确保使用有序因子对字母等级进行正确分类是合适的:
library(tidyr)
library(ggplot2)
dat <- data.frame(grade1 = c('A','A','A','B','B','C'), grade2 = c('A','B','C','C','D','D'))
tidy_dat <- gather(dat)
tidy_dat[,2] <- ordered(tidy_dat[,2], levels = c('A','B','C','D'))
ggplot(tidy_dat, aes(x= value, fill = key))+
geom_bar(position = 'dodge')