geopandas.GeoSeries.touches#
- GeoSeries.touches(other, align=None)[来源]#
返回一个
Series,其dtype('bool')为True,对于每个与 other 相接触的对齐几何体。如果一个对象与其他有至少一个公共点,并且它的内部与其他任何部分不相交,则该对象被称为与其他接触。因此,重叠的特征不算接触。
该操作以一对一的行方式进行:
- Parameters:
- otherGeoSeries or geometric object
要测试是否被触及的GeoSeries(逐元素)或几何对象。
- alignbool | None (default None)
如果为真,则根据其索引自动对齐GeoSeries。 如果为假,则保留元素的顺序。 None默认为真。
- Returns:
- Series (bool)
笔记
该方法以逐行的方式工作。它不检查一个 GeoSeries 的元素是否
touches任何 另一个的元素。示例
>>> from shapely.geometry import Polygon, LineString, MultiPoint, Point >>> s = geopandas.GeoSeries( ... [ ... Polygon([(0, 0), (2, 2), (0, 2)]), ... Polygon([(0, 0), (2, 2), (0, 2)]), ... LineString([(0, 0), (2, 2)]), ... MultiPoint([(0, 0), (0, 1)]), ... ], ... ) >>> s2 = geopandas.GeoSeries( ... [ ... Polygon([(0, 0), (-2, 0), (0, -2)]), ... LineString([(0, 1), (1, 1)]), ... LineString([(1, 1), (3, 0)]), ... Point(0, 1), ... ], ... index=range(1, 5), ... )
>>> s 0 POLYGON ((0 0, 2 2, 0 2, 0 0)) 1 POLYGON ((0 0, 2 2, 0 2, 0 0)) 2 LINESTRING (0 0, 2 2) 3 MULTIPOINT ((0 0), (0 1)) dtype: geometry
>>> s2 1 POLYGON ((0 0, -2 0, 0 -2, 0 0)) 2 LINESTRING (0 1, 1 1) 3 LINESTRING (1 1, 3 0) 4 POINT (0 1) dtype: geometry
我们可以检查每个GeoSeries的几何图形是否与单个几何图形接触:
>>> line = LineString([(0, 0), (-1, -2)]) >>> s.touches(line) 0 True 1 True 2 True 3 True dtype: bool
我们还可以逐行检查两个GeoSeries。 上面的GeoSeries具有不同的索引。我们可以基于索引值对两个GeoSeries进行对齐,并使用相同索引比较元素,使用
align=True,或者忽略索引并根据它们的匹配顺序比较元素,使用align=False:>>> s.touches(s2, align=True) 0 False 1 True 2 True 3 False 4 False dtype: bool
>>> s.touches(s2, align=False) 0 True 1 False 2 True 3 False dtype: bool