geopandas.GeoSeries.disjoint#
- GeoSeries.disjoint(other, align=None)[来源]#
返回一个
Series,其dtype('bool')的值为True,对于每个与 other 不相交的对齐几何体。一个对象被称为与 其他 不相交,如果它的 边界 和 内部 与其他对象的边界和内部完全不相交。
该操作以一对一的行方式进行:
- Parameters:
- otherGeoSeries or geometric object
要测试是否不相交的GeoSeries(逐元素)或几何对象。
- alignbool | None (default None)
如果为真,则根据其索引自动对齐GeoSeries。 如果为假,则保留元素的顺序。 None默认为真。
- Returns:
- Series (bool)
笔记
该方法以行的方式工作。它不检查一组GeoSeries的元素是否等于另一组中任何元素。
示例
>>> from shapely.geometry import Polygon, LineString, Point >>> s = geopandas.GeoSeries( ... [ ... Polygon([(0, 0), (2, 2), (0, 2)]), ... LineString([(0, 0), (2, 2)]), ... LineString([(2, 0), (0, 2)]), ... Point(0, 1), ... ], ... ) >>> s2 = geopandas.GeoSeries( ... [ ... Polygon([(-1, 0), (-1, 2), (0, -2)]), ... LineString([(0, 0), (0, 1)]), ... Point(1, 1), ... Point(0, 0), ... ], ... )
>>> s 0 POLYGON ((0 0, 2 2, 0 2, 0 0)) 1 LINESTRING (0 0, 2 2) 2 LINESTRING (2 0, 0 2) 3 POINT (0 1) dtype: geometry
>>> s2 0 POLYGON ((-1 0, -1 2, 0 -2, -1 0)) 1 LINESTRING (0 0, 0 1) 2 POINT (1 1) 3 POINT (0 0) dtype: geometry
我们可以将GeoSeries中的每个几何体检查为一个单一的几何体:
>>> line = LineString([(0, 0), (2, 0)]) >>> s.disjoint(line) 0 False 1 False 2 False 3 True dtype: bool
我们还可以逐行检查两个GeoSeries之间的关系。我们可以通过基于索引值对齐两个GeoSeries,并使用相同索引比较元素,使用
align=True,或者忽略索引并根据相应顺序比较元素,使用align=False:>>> s.disjoint(s2) 0 True 1 False 2 False 3 True dtype: bool