使用geopandas将数据框中的点行制作成多边形

Making rows of points in dataframe into POLYGON using geopandas

我试图找出点是否在闭合多边形中(在这个问题中:Finding if a point in a dataframe is in a polygon and assigning polygon name to point)但我意识到可能还有另一种方法可以做到这一点:

我有这个数据框

df=
id     x_zone     y_zone
0  A1  65.422080  48.147850
1  A1  46.635708  51.165745
2  A1  46.597984  47.657444
3  A1  68.477700  44.073700
4  A3  46.635708  54.108190
5  A3  46.635708  51.844770
6  A3  63.309560  48.826878
7  A3  62.215572  54.108190

我想将其转换为

id     Polygon
0  A1  POLYGON((65.422080, 48.147850), (46.635708,  51.165745), (46.597984,  47.657444), (68.477700,  44.073700))
1  A3  POLYGON((46.635708,54.108190), (46.635708 ,51.844770), (63.309560, 48.826878),(62.215572 , 54.108190))

对积分做同样的事情:

df1= 

 item   x   y
0     1  50  49
1     2  60  53
2     3  70  30

item   point
0     1  POINT(50,49)
1     2  POINT(60,53)
2     3  POINT(70,30)

我从来没有用过geopandas,有点不知所措。

因此我的问题是:如何从 pandas 数据框获取具有 geopandas 属性的数据框?

感谢任何见解!

您可以实现如下,但您必须设置正确的数据类型。我知道在 ArcGIS 中您必须将数据类型设置为几何;

df.groupby('id').apply(lambda x: 'POLYGON(' + str(tuple(zip(x['x_zone'],x['y_zone'])))+')')

我建议使用以下方法直接从您的 df 获取 GeoDataFrame:

from shapely.geometry import Polygon
import geopandas as gpd
gdf = gpd.GeoDataFrame(geometry=df.groupby('name').apply(
    lambda g: Polygon(gpd.points_from_xy(g['x_zone'], g['y_zone']))))

它首先使用 geopandas points_from_xy 创建一个点列表,然后从该列表创建一个多边形对象。