geopandas.GeoSeries.disjoint#

GeoSeries.disjoint(other, align=None)[来源]#

返回一个 Series,其 dtype('bool') 的值为 True,对于每个与 other 不相交的对齐几何体。

一个对象被称为与 其他 不相交,如果它的 边界内部 与其他对象的边界和内部完全不相交。

该操作以一对一的行方式进行:

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

../../../_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