geopandas.GeoSeries.disjoint#

GeoSeries.disjoint(other, align=True)#

返回一个 Seriesdtype('bool') 有价值的 True 对于每个与不相交的对齐几何图形 other

一个物体称为与不相交 other 如果它的 boundaryinterior 与另一个完全不相交。

该操作以1对1的行方式工作:

../../../_images/binary_op-01.svg
参数
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的每个几何体检查到单个几何体:

../../../_images/binary_op-03.svg
>>> 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

../../../_images/binary_op-02.svg
>>> s.disjoint(s2)
0     True
1    False
2    False
3     True
dtype: bool