我有两个GeoDataFrame。一个包含点,另一个包含多边形。
我需要从GeoDataFrame获取任何多边形内的所有点。
我尝试遍历所有多边形,并检查Point是否在此多边形内。此解决方案有效,但速度很慢。
我想知道是否还有另一种方法可以解决此任务。
编辑:我的解决方案如下所示:
for i in range(len(Poly_gdf.index)):
inter = Points_gdf[Points_gdf.intersects(Poly_gdf.loc[i,'geometry'])]
if not inter.empty:
for i in inter['geometry'].values:
points.append(i)
使用空间连接,这是经过优化的并且应该是快速的。
See documentation for details.
points_within = gpd.sjoin(Points_gdf, Poly_gdf, op='within')