不打算编辑拓扑,只是将所有多边形聚合成一个sp
类型的对象SpatialPolygonsDataFrame
(spdf)。每个 spdf 只有一个多边形。
数据(数据的保管箱链接)(文件大小 1.1KB)(dput()
在这种情况下不合适):
list_of_spdf <- unlist(readRDS("data.Rds"))
我得到了想要的结果:
one_spdf <- rbind(list_of_spdf[1][[1]], list_of_spdf[2][[1]], list_of_spdf[3][[1]], makeUniqueIDs = TRUE)
# when plotting can see two polygons (third object is a repeat for sake of testing)
plot(one_spdf)
拥有数百个对象(尽管每个 spdf 只有一个多边形),我需要以rbind
编程方式进行。所以我尝试了lapply
list_of_spdf <- lapply(list_of_spdf, rbind, makeUniqueIDs = TRUE)
显然,这会返回一个列表,因此不是我要找的。
所以我写了一个函数:
rbindSPDF <- function(lst) {
# Create empty spdf objects
pol <-
SpatialPolygonsDataFrame(SpatialPolygons(list()), data = data.frame())
pols <-
SpatialPolygonsDataFrame(SpatialPolygons(list()), data = data.frame())
# loop for rbind
for (i in 1:length(lst)) {
pol[i] <- lst[i][[1]]
if (length(pols) == 0) {
pols <- pol[i]
} else {
pols <- rbind(pols, pol[i], makeUniqueIDs = TRUE)
}
}
return(pols)
}
但是,使用时rbindSPDF
:
single_spdf <- rbindSPDF(list_of_spdf)
我得到:
Error in as.vector(data) :
no method for coercing this S4 class to a vector
不知道我在这里做错了什么。
另外,我猜我可能甚至不需要使用我自己的函数。
注意:在许多其他包之上,我正在使用sp
andrgdal
来处理空间数据,并且由于附加/分离时间和掩蔽,我宁愿避免使用另一个包。