【发布时间】:2017-06-02 16:45:03
【问题描述】:
我对使用 QGIS 很陌生,我有一个点 shapefile 和一个多边形 shapefile。我想选择其中至少有一个点的所有多边形。我遇到的问题是这需要多长时间。我有 100 万个点和大约 320,000 个多边形,因此使用空间查询需要很长时间。我听说我需要编写一个带有空间索引的 python 脚本才能获得一个可行的快速结果,但我不知道如何解决这个问题。任何帮助将不胜感激。
我试图从其他堆栈溢出问题中拼凑出来的是:
pointProvider = self.pointLayer.dataProvider()
all_point = pointProvider.getFeatures()
delta = 0.1
for point in all_point:
searchRectangle = QgsRectangle(point.x() - delta, point.y() - delta, point.x() + delta, point.y() + delta)
candidateIDs = line_index.intesects(searchRectangle)
for candidateID in candidateIDs:
candFeature == rotateProvider.getFeatures(QgsFeatureRequest(candidateID)).next()
if candFeature.geometry().contains(point):
break
这会引发 NameError: name 'self' is not defined
【问题讨论】:
标签: polygon point qgis spatial-index