怎么知道剧情的名字? [重复]

问题描述 投票:2回答:1

这个问题在这里已有答案:

在for循环中使用ggplot2不会显示我想要将图表打印到一个页面并保存它们的图表名称

我有60个csv文件,每个文件由两列组成,第一列是日期,第二列是ssh,每行都有不同的行号。我将它们列在变量调用文件中,然后我绘制它们。 for循环产生了60个图。问题是当我需要时,如何知道这些图的名称来调用它们。在一页打印4个图,所以最后我将有15页,每页包含4个图。我用的时候

library(gridExtra)
grid.arrange(p1,p2,p3,p4, nrow=2,ncol=2)
grid.arrange(p5,p6,p7,p8, nrow=2,ncol=2) 

等到第60页它没有显示结果。警告消息说没有对象叫做p1,p2,p3,p4,.... p60。

代码如下:

files<- list.files("F:/R Practice/time series")
for (i in seq_along(files)){
  mydf <- read.csv(files[i], stringsAsFactors=FALSE)
  a<- data.frame(as.Date(mydf$date, "%d-%m-%y"),mydf[,-1])
  names(a)[1]<- "Date"
  names(a)[2]<- "SSH"
  b <- zoo(a[,-1],order.by=as.Date(a[,1]))
  p<- ggplot(a, aes(x=Date,y=SSH, color=SSH)) +geom_line(colour="darkblue")# +labs(title = "gridcell of (31.25N, 33.25E) ",x="Date", y="SSH")
  p<-p+ggtitle(readline(prompt = "enter cell coordinates:  "))+xlab("Year")+ylab("weighted average SSH of center cell")
  # adding atrribute to the plot p[i]
  p<-p+theme(axis.title.x=element_text(color = "black",size = 12),
               axis.title.y=element_text(color = "black",size = 8),
               axis.text.x=element_text(color="black",size=8),
               axis.text.y = element_text(color = "black",size = 8),
               panel.background = element_rect(colour = "black", size=0.5 ,fill = NA),
               panel.grid.minor = element_blank(),
               panel.grid.major = element_blank(),
               axis.line = element_line(colour = "black",size=1),
               legend.position="none" ,
           plot.title=element_text(hjust = 0.5,vjust= 0.5,lineheight = .3,face = "bold"))

  print(p)
}
r ggplot2
1个回答
2
投票

你的代码每次都覆盖p到最后一个情节。这里有一个更简单的代码,使用ggplot2帮助示例中的示例,但是有一个类似于你的循环。

df <- data.frame(
       gp = factor(rep(letters[1:3], each = 10)),
       y = rnorm(30)
   )

p.list<- list()
for (i in 1:4)
{
  df<- sample_frac(df, 0.5)

  p<- ggplot(df, aes(gp, y)) +
    geom_point() +
    geom_point(data = ds, aes(y = mean), colour = 'red', size = 3)
  p.list[[i]] <-p
}

grid.arrange(p.list[[1]], p.list[[2]], p.list[[3]], p.list[[4]], nrow= 2 )

注意两件事:

  1. p.list开始是一个空列表。
  2. 在每个循环结束时,您将一个图添加到增长列表的编号元素,即p.list[[i]] <- p
  3. p.list成长为一个列表,每个编号元素(1:4)都有一个单独的图,每个图也是一个命名列表。
© www.soinside.com 2019 - 2024. All rights reserved.