【问题标题】:plot with ggplot in for-loop doesn't work [duplicate]在for循环中使用ggplot绘图不起作用[重复]
【发布时间】:2014-02-11 09:54:20
【问题描述】:

我制作了 ggplot,它显示了一个物种的种群数量。这个脚本运行良好。所以我做了 for-loop 来链接为 25 个物种生成这个图,但它不起作用。

这是一个物种的例子:

A <- data.frame(sp="A",x=c(rep(0.1,3),rep(2,3),rep(4.5:8.5,4),6.5), width=c(rep(NA,3), rep(4,3), rep(1,20),5),y=c(rep(1:3,2), rep(1:4, each=5),5),col=c(rep("white",21), rep("grey80",6)), name1=c("C.I. (%)","C.N. (%)", rep("",25)), name1i=c(rep("",2), "Total",rep("",24)), nb1=c(rep(NA,7),1.33,0.53,0.52,0.42,NA,27.12,10.90,10.55,8.56,rep(NA,11)),nb2=c(rep(NA,16),24754,13558,5449,5273,4281,rep(NA,6)),nb3=c(rep(NA,6),2.43,rep(NA,4),49.51, rep(NA,15)), name2=c(rep("",21),"J","F","M","A","M","Month"))

library(ggplot2)
library(gridExtra)
  table <- A
  windows()
  ggplot(table, aes(x=x, y=y, width=width, fill=col))+
    geom_tile(colour="black")+
    scale_fill_manual(values = c("white"="white", "grey80"="grey80"),    
                      breaks = levels(table$col), na.value = "white")+
    geom_text(aes(label=name1), size=6, hjust=0)+
    geom_text(aes(label=name1i), size=6, hjust=0, fontface=3)+
    geom_text(aes(label=nb1), size=6)+
    geom_text(aes(label=nb2), size=6, fontface=3)+
    geom_text(aes(label=nb3), size=6, fontface="bold")+
    geom_text(aes(label=name2), size=6, fontface="bold")+
    coord_cartesian(xlim=c(0,9), ylim=c(0.5,5.5))+
    labs(x = "",y = "") +                   
    scale_x_discrete(expand = c(0, 0)) +   
    scale_y_discrete(expand = c(0, 0))+     
    theme(axis.ticks = element_blank(),     
          axis.text = element_blank(),      
          legend.position = "none",        
          panel.background = element_rect(fill='white', colour='white'),   
          plot.margin = unit(c(0.5,0.5,-1,-1), "lines"))  

对于两个带有 for 循环的物种:

A <- data.frame(sp="A",x=c(rep(0.1,3),rep(2,3),rep(4.5:8.5,4),6.5), width=c(rep(NA,3), rep(4,3), rep(1,20),5),y=c(rep(1:3,2), rep(1:4, each=5),5),col=c(rep("white",21), rep("grey80",6)), name1=c("C.I. (%)","C.N. (%)", rep("",25)), name1i=c(rep("",2), "Total",rep("",24)), nb1=c(rep(NA,7),1.33,0.53,0.52,0.42,NA,27.12,10.90,10.55,8.56,rep(NA,11)),nb2=c(rep(NA,16),24754,13558,5449,5273,4281,rep(NA,6)),nb3=c(rep(NA,6),2.43,rep(NA,4),49.51, rep(NA,15)), name2=c(rep("",21),"J","F","M","A","M","Month"))
B <- data.frame(sp="B",x=c(rep(0.1,3),rep(2,3),rep(4.5:8.5,4),6.5), width=c(rep(NA,3), rep(4,3), rep(1,20),5),y=c(rep(1:3,2), rep(1:4, each=5),5),col=c(rep("white",21), rep("grey80",6)), name1=c("C.I. (%)","C.N. (%)", rep("",25)), name1i=c(rep("",2), "Total",rep("",24)), nb1=c(rep(NA,6),4.5,6.74,3.43,3.56,NA,19.89,29.82,15.18,15.75,rep(NA,12)),nb2=c(rep(NA,16),3282,4920,2504,2599,5328,rep(NA,6)),nb3=c(rep(NA,10),7.30,rep(NA,4),32.29, rep(NA,11)), name2=c(rep("",21),"J","F","M","A","M","Month"))
data <- rbind(A,B)
sp <- c("A","B")

library(ggplot2)
library(gridExtra)
for(i in sp){
  table <- data[data$sp==i,]
  windows()
  ggplot(table, aes(x=x, y=y, width=width, fill=col))+
    geom_tile(colour="black")+
    scale_fill_manual(values = c("white"="white", "grey80"="grey80"),    
                      breaks = levels(table$col), na.value = "white")+
    geom_text(aes(label=name1), size=6, hjust=0)+
    geom_text(aes(label=name1i), size=6, hjust=0, fontface=3)+
    geom_text(aes(label=nb1), size=6)+
    geom_text(aes(label=nb2), size=6, fontface=3)+
    geom_text(aes(label=nb3), size=6, fontface="bold")+
    geom_text(aes(label=name2), size=6, fontface="bold")+
    coord_cartesian(xlim=c(0,9), ylim=c(0.5,5.5))+
    labs(x = "",y = "") +                   
    scale_x_discrete(expand = c(0, 0)) +   
    scale_y_discrete(expand = c(0, 0))+    
    theme(axis.ticks = element_blank(),    
          axis.text = element_blank(),     
          legend.position = "none",         
          panel.background = element_rect(fill='white', colour='white'),   
          plot.margin = unit(c(0.5,0.5,-1,-1), "lines"))  
}

情节是空的,没有错误消息,所以我不明白我的错误在哪里。这只是一个ggplot问题吗?事实上我不这么认为,因为其他 ggplot 与 for-loop 配合得很好...... 你有什么主意吗? 感谢您的帮助!

【问题讨论】:

  • pl = plyr::dlply(data, "sp", "%+%", e1=last_plot()); do.call(grid.arrange, pl)
  • @Ma。我已经删除了我的答案,因为它不起作用。
  • 感谢 baptiste 和 amzu 对我的问题感兴趣。我认为最简单的解决方案是@jlhoward 答案。

标签: r for-loop ggplot2


【解决方案1】:

qplot() 需要在 for 循环中使用 print()

例如我有以下格式的代码,但使用qplot()时只创建了空白图像文件

for(loop1 in rangestart:rangeend)  
{  
   ..........  
   ..........  
   png(Imagefile,width=1366,height=768)  
   qplot(.....)  
   dev.off()  
}

qplot(.....) 替换为print(qplot(.....)) 解决了问题

【讨论】:

    【解决方案2】:

    问题在于 for 循环。您需要在循环中使用 print。

    for (i in sp) {
      table <- data[data$sp=="A",]
      windows()
      ggp <- ggplot(...) + ...
      print(ggp)
    }
    

    考虑这个简单的例子:

    library(ggplot2)
    df=data.frame(x=1:10,y=rnorm(10))                       # sample data
    ggplot(df)+geom_point(aes(x,y))                         # render ggplot
    for (i in 1:2) ggplot(df)+geom_point(aes(x,y))          # nothing
    for (i in 1:2) print(ggplot(df) + geom_point(aes(x,y))) # renders
    

    另外,正如@user229552 所说,您两次都使用同一张表。

    【讨论】:

      【解决方案3】:

      首先,您似乎总是选择“A”子集。 for 循环的开头应如下所示:

      for(i in sp){
       table <- data[data$sp==i,]
      

      【讨论】:

        猜你喜欢
        • 2015-05-17
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2017-11-03
        • 2014-11-03
        • 2015-01-05
        • 1970-01-01
        相关资源
        最近更新 更多