我的ggplot在韩国七个大都市地区的多面多线图问题。
我的csv数据集的结构与面板数据类似,具有随时间推移城市的横截面和时间序列维度。
下面是我的数据集的格式:
Year City VKT index GDP index
2012 Seoul 100 100
2013 Seoul 94 105
2014 Seoul 96 110
..............................
2012 Busan 100 100
2013 Busan 97 105
..............................
2012 Daegu 100 100
2013 Daegu 104 114
我的代码也如下:
deccity <- read_csv("decouplingbycity.csv")
deccity %>% filter(is.na(Year) == FALSE) %>%
ggplot(deccity, mapping = aes(x=Year)) +
geom_line(size = 1, aes(y = `GDP index`), color = "darkred") +
geom_line(size = 1,aes(y = `VKT index`), color="steelblue", linetype="twodash")+
labs(y="Index: 1992=100",
title = "Decoupling by city")+
facet_wrap(~City)
您可以看到我现在得到的情节。但是有一个问题,一个明显的问题是我看不到“ VKT指数”和“ GDP指数”变量的图例。我将不胜感激,如果有人可以插话并找出另一种方式来做到这一点。
请参考我的无图例的多面板图,以更深入地了解我要寻找的内容:
我的建议是以“整洁”的方式重塑数据,这样可以避免将来遇到很多麻烦(不仅是ggplot2)。请参阅this精美的文档。
这里的问题不是facet_grid()
函数,而是告诉ggplot2要包括在图例中的数据的方式;该数据必须在aes()
内部。
由于您没有提供可复制的数据集,因此我使用RStudio中包含的mtcars
数据集。只需复制粘贴下面的代码,它就会运行。
# very usefull set of packages
library(tidyverse)
# here is what you are trying to do
ex_plot1 = ggplot(data = mtcars, aes(x = disp)) +
geom_line(aes(y = mpg), color = "red") +
geom_line(aes(y = qsec), color = "green")
plot(ex_plot1) # see there is no legend
# reshape your data this way:
ex_data2 = pivot_longer(data = mtcars,
cols = c("mpg", "qsec"),
values_to = "values",
names_to = "colored_var")
# and then plot it, legend appears
ex_plot2 = ggplot(data = ex_data2, aes(x = disp, y = values, color = colored_var)) +
geom_line()
plot(ex_plot2)
[[EDIT]添加了输出
无图例,ex_plot1
带有图例的图,ex_plot2