在ggplot2中组合条形图和折线图(双轴)

AK4*_*K47 17 r linechart bar-chart ggplot2 yaxis

我有double-y-axis图表制作Excel.在Excel中,它只需要基本技能.我想做的是使用ggplot2库复制此图表R.

在此输入图像描述

我已经这样做了,但我需要绘制Response 2nd-y-axis.

在此输入图像描述

我附上了我用过的可重现的代码:

#Data generation
Year <- c(2014, 2015, 2016)
Response <- c(1000, 1100, 1200)
Rate <- c(0.75, 0.42, 0.80)

df <- data.frame(Year, Response, Rate)

#Chart
library(ggplot2)

ggplot(df)  + 
  geom_bar(aes(x=Year, y=Response),stat="identity", fill="tan1", colour="sienna3")+
  geom_line(aes(x=Year, y=Rate),stat="identity")+
  geom_text(aes(label=Rate, x=Year, y=Rate), colour="black")+
  geom_text(aes(label=Response, x=Year, y=0.9*Response), colour="black")
Run Code Online (Sandbox Code Playgroud)

set*_*ler 23

首先,规模RateRate*max(df$Response)和修改0.9响应文本的规模.

其次,包括第二轴scale_y_continuous(sec.axis=...):

ggplot(df)  + 
    geom_bar(aes(x=Year, y=Response),stat="identity", fill="tan1", colour="sienna3")+
    geom_line(aes(x=Year, y=Rate*max(df$Response)),stat="identity")+
    geom_text(aes(label=Rate, x=Year, y=Rate*max(df$Response)), colour="black")+
    geom_text(aes(label=Response, x=Year, y=0.95*Response), colour="black")+
    scale_y_continuous(sec.axis = sec_axis(~./max(df$Response)))
Run Code Online (Sandbox Code Playgroud)

产量:

在此输入图像描述

  • 你好,我怎样才能改变次y轴的极限?我正在尝试使用百分比(已经乘以100)创建类似的图表,并且辅助图表上的比例不合适.谢谢! (3认同)
  • 我和@user3047435 遇到了同样的问题。我尝试过的很多事情都弄乱了缩放比例,因此例如,Rate 是正确的,但 Response 被丢弃了。最终,我最终将原始百分比重新除以 100,然后在缩放中再次乘以它,如下所示:`scale_y_continuous(sec.axis = sec_axis(~./max(df$Response)*100) )`。 (2认同)