首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >存储大量栅格的栅格名称和表示

存储大量栅格的栅格名称和表示
EN

Stack Overflow用户
提问于 2019-02-23 00:20:58
回答 1查看 12关注 0票数 0

对于非常多的栅格,我需要在栅格上循环,并获得栅格的名称和栅格的平均单元值。

这段代码工作正常,但只存储循环中最后一个元素的结果,当然我需要为每个i (=for each raster)存储它。

代码语言:javascript
复制
 for(i in ras){
      dfff$A <- cellStats(i,"mean")
      dfff$B <- i 
    }

我需要的是一个代码来存储每个栅格的结果,包括名称和均值(这样就可以很容易地看到哪个均值对应于哪个栅格)。这个代码会导致致命的错误。

代码语言:javascript
复制
   for(i in ras){
      dfff[i]$A <- cellStats(i,"mean")
      dfff[i]$B <- i 
    }

有谁知道怎么解决这个问题吗?

EN

回答 1

Stack Overflow用户

发布于 2019-02-23 00:50:21

如果栅格具有相同的原点和范围,则只需执行以下操作

代码语言:javascript
复制
library(raster)
s <- stack(ras)
cellStats(s)

否则,您可以在循环中执行cellStats

代码语言:javascript
复制
d <- rep(NA, length(ras))
nms <- rep(NA, length(ras))
for(i in 1:length(ras)){
     d[i] <- cellStats(ras[[i]], "mean")
     nms[i] <- names(ras[[i]])
}

我不知道你说的栅格的“名字”是什么意思。在您的代码中,您将整个对象分配给"B“。但无论哪种方式,您都不需要在循环中这样做,因为您已经有了一个栅格列表(我假设这就是ras )。所以你也可以这样做

代码语言:javascript
复制
nms <- sapply(ras, names)

或者你指的是文件名?

代码语言:javascript
复制
nms <- sapply(ras, filename)

现在你可以做

代码语言:javascript
复制
df <- data.frame(name=nms, mean=d)

第二个循环的问题是i不是一个数字索引,它是一个光栅对象。所以你不能做diff[i]

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54831185

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档