geopandas.GeoSeries.disjoint#
- GeoSeries.disjoint(other, align=True)#
返回一个
Series
的dtype('bool')
有价值的True
对于每个与不相交的对齐几何图形 other 。一个物体称为与不相交 other 如果它的 boundary 和 interior 与另一个完全不相交。
该操作以1对1的行方式工作:
- 参数
- otherGeoSeries或几何对象
要测试是否不相交的GeoSeries(元素级)或几何对象。
- align布尔值(默认为True)
如果为True,则根据其索引自动对齐GeoSeries。如果为False,则保留元素的顺序。
- 退货
- 系列(布尔图)
注意事项
此方法以行方式工作。它不会检查某个GeoSeries的元素是否等于 any 另一个元素的元素。
示例
>>> 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.00000 0.00000, 2.00000 2.00000, 0.... 1 LINESTRING (0.00000 0.00000, 2.00000 2.00000) 2 LINESTRING (2.00000 0.00000, 0.00000 2.00000) 3 POINT (0.00000 1.00000) dtype: geometry
>>> s2 0 POLYGON ((-1.00000 0.00000, -1.00000 2.00000, ... 1 LINESTRING (0.00000 0.00000, 0.00000 1.00000) 2 POINT (1.00000 1.00000) 3 POINT (0.00000 0.00000) 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