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

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

我已经做到了,但是我需要在2nd-y-axis上绘制Response。

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

我附上我使用过的可复制代码:

#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")

最佳答案

首先,将Rate缩放为Rate*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)))


产生:

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

关于r - 在ggplot2中组合条形图和折线图(双轴),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41764312/

10-10 18:31