R:ggplot2在一个图中绘制几个数据帧

时间:2018-11-29 11:15:45

标签: r dataframe ggplot2

我有点想停在ggplot2上,试图在一个图中绘制多个数据帧。

在这里我有几个数据框,我仅介绍两个示例。

数据帧具有相同的标头,但不同。假设我要计算2个盒子中的球数。

name=c('red','blue','green','purple','white','black')
value1=c(2,3,4,2,6,8)
value2=c(1,5,7,3,4,2)

test1=data.frame("Color"=name,"Count"=value1)
test2=data.frame("Color"=name,"Count"=value2)

我要做的是绘制我的数量的条形图。 目前我所做的是:

(plot_test=ggplot(NULL, aes(x= Color, y=Count)) + 
    geom_bar(data=test1,stat = "identity",color='green')+
    geom_bar(data=test2,stat = "identity",color='blue')
)

Problem is that my plots are overlapping themselves

我想让x = Color和y = Count,以及test1旁边的test2数据框的条形图。这里有重叠的自己。因此,我将在x中使用两次相同的名称,但我想用几种颜色绘制数据框,并在图例中获得名称。

例如“绿条” = test1             “蓝条” = test2

感谢您的时间和帮助。

最诚挚的问候

3 个答案:

答案 0 :(得分:3)

尝试一下:

name=c('red','blue','green','purple','white','black')
value1=c(2,3,4,2,6,8)
value2=c(1,5,7,3,4,2)

test1=data.frame("Color"=name,"Count"=value1)
test2=data.frame("Color"=name,"Count"=value2)

test1$var <- 'test1'
test2$var <- 'test2'

test_all <- rbind(test1,test2)


(plot_test=ggplot(data=test_all) + 
  geom_bar(aes(x=Color,y=Count,color=var),
           stat = "identity", position=position_dodge(1))+
  scale_color_manual(values = c('green', 'blue'))
)

答案 1 :(得分:2)

您在这里有两个选择:

调整条形的大小和位置

ggplot(NULL, aes(x= Color, y=Count)) + 
geom_bar(data=test1, aes(color='test1'), stat = "identity",
         width=.4, position=position_nudge(x = -0.2)) +
geom_bar(data=test2, aes(color='test2'), stat = "identity", 
         width=.4, position=position_nudge(x = 0.2))

enter image description here 或者我建议将两个数据框连接在一起,然后绘制

library(dplyr)
test1 %>% 
  full_join(test2, by = 'Color') %>% 
  data.table::melt(id.vars = 'Color') %>% 
  ggplot(aes(x= Color, y=value, fill = variable)) + 
  geom_bar(stat = "identity", position = 'dodge')

enter image description here

答案 2 :(得分:0)

这将完成您想做的事情:

balls <- data.frame(
  count = c(c(2,3,4,2,6,8),c(1,5,7,3,4,2)),
  colour = c(c('red','blue','green','purple','white','black'),c('red','blue','green','purple','white','black')),
  box = c(rep("1", times = 6), rep("2", times = 6))
)

ggplot(balls, aes(x = colour, y = count, fill = box)) +
  geom_col() +
  scale_fill_manual(values = c("green","blue"))

这是更好的方法,因为它可以帮助比较框数:

ggplot(balls, aes(x = colour, y = count)) +
  geom_col() +
  facet_wrap(~ box, ncol = 1, labeller = as_labeller(c("1" = "Box #1", "2" = "Box #2")))