我正在用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值的点。这就是现在发生的事情:
任何人都可以帮助我吗?
答案 0 :(得分:0)
很难说没有你的数据你想做什么,但为什么你需要这个循环呢?这样的事情应该有效:
ggplot(df, aes(Capacity, y = CperkWh, group=factor(Powerlist), color = PDC)) +
geom_line() +
geom_point()