我在R中使用ggplot創建陰謀,並且我使用了一個循環來加速我的繪圖時間。不過,我有問題在同一個圖中繪製多行。 數據:R:如何在ggplot中使用一個循環繪製一條陰影中的多條線
df <- c("Results", "Capacity", "Power", "LDI","LDE", "LB", "PDC","D")
一些數據
Results Capacity Power LDI LDE PDC D CperkWh
1 ImpactDC 1.00 PG20 LDI0.01 LDE0 PDC0 D10 0.010950532
2 ImpactDC 0.95 PG10 LDI0.02 LDE0 PDC0 D10 0.080374607
3 ImpactDC 0.90 PG50 LDI0.003 LDE0 PDC0 D10 0.010158171
4 ImpactDC 0.85 PG5 LDI0.05 LDE0 PDC0 D10 0.006994843
5 ImpactDC 0.80 PG3 LDI0.02 LDE0 PDC0 D10 0.009684512
6 ImpactDC 0.75 PG20 LDI0 LDE0 PDC0 D10 0.007891302
基於here,看起來像這樣我使用的循環:
Power.graph <- function(df, na.rm = TRUE, ...){
Powerlist <- unique(df$Power)
for (i in seq_along(Powerlist)){
plot <-
ggplot(subset(df, df$Power==Powerlist[i]),
aes(Capacity, y = CperkWh), group = df$Power, colour = PDC) +
geom_line() +
geom_point()+
theme(axis.text.x = element_text(size=12))+
facet_wrap(~ PDC, ncol =1)+
theme(legend.position = "none")+
scale_y_continuous("Income in €/kWh")+
scale_x_continuous("Capacity of the line")+
ggtitle(paste(Powerlist[i], ' Capacity of the line \n',
"Income per kWh \n",
sep=''))
#save plot as PNG
ggsave(plot = last_plot(), file= paste(StoreResults, '/Results/',
Powerlist[i], "YesDCNoV2G.png", sep=''), scale=2)
print(plot)
}
}
#Run the function
Power.graph(df)
我想什麼做的是積對於LDI的每個值,分別有多行(所以圖CperkWh)。當我運行該程序時,我收到的圖是我想要的,但geom_line命令連接所有點,我希望它只連接具有相同LDI值的點。這是現在發生的事情:
任何人都可以幫助我嗎?
你能否提供一些樣本數據,而不僅僅是你的列名? – cmaher
好像你可能需要將'group'移到'aes'裏面。嘗試添加一個[可重現的例子](https://stackoverflow.com/questions/5963269/how-to-make-a-great-r-reproducible-example),所以人們可以幫助你更好。 – aosmith
謝謝你的提示:我已經添加了一些數據。 – ima