首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从坐标列到几何学

从坐标列到几何学
EN

Stack Overflow用户
提问于 2020-06-30 02:35:35
回答 2查看 2.9K关注 0票数 2

我有一个DataFrame,它有一列坐标列表,如下所示:

我想让这个DataFrame成为一个带有geometry列的GeoPandas DataFrame。一种方法是创建两个表示纬度和经度的列表,并将第一个和第二个元素分别从coors列存储到纬度和经度。然后使用gpd.points_from_xy来构建几何学列。但是这种方法增加了构建GeoPandas DataFrame的额外步骤。我的问题是如何直接从geometry coors list构建

我在这里添加一些测试数据:

代码语言:javascript
复制
import pandas ad pd
import geopandas as gpd

data = {'id':[0,1,2,3], 'coors':[[41,-80],[40,-76],[35,-70],[35,-87]]}
df = pd.DataFrame.from_dict(data)
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-06-30 08:22:45

您只需将Point应用于'coors'列以生成点几何。

代码语言:javascript
复制
from shapely.geometry import Point

df['geometry'] = df.coors.apply(Point)
gdf = gpd.GeoDataFrame(df)  # you should also specify CRS
票数 2
EN

Stack Overflow用户

发布于 2022-01-13 04:36:01

在分隔列中有纬度和经度的情况下,可以这样做:

代码语言:javascript
复制
import pandas as pd
import geopandas as gpd
from shapely.geometry import Point

def create_geometry(row):
  row["geometry"] = Point(row["latitude"],row["longitude"])
  return row

df = pd.read_[parquet|csv|etc]("file")
df = df.apply(create_geometry,axis=1)
gdf = gpd.GeoDataFrame(df,crs=4326)

然后,您可以验证它执行以下操作:

代码语言:javascript
复制
df.geometry.head(1)

输出

代码语言:javascript
复制
16    POINT (7.88507 -76.63130)
Name: geometry, dtype: geometry
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62649446

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档