GeoPandas初体验:它是什么,我用它展示一下shp矢量数据

2023-12-08 23:44

本文主要是介绍GeoPandas初体验:它是什么,我用它展示一下shp矢量数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

GeoPandas 是一个开源的 Python 库,用于处理地理空间数据。它扩展了 Pandas 这个流行的 Python 数据操作库,增加了对地理数据类型和操作的支持。GeoPandas 结合了 Pandas、Matplotlib 和 Shapely 的功能,提供了一个易于使用且高效的工具,用于处理地理空间数据。

GeoPandas 是一个开源项目,用于处理地理空间 Python 中的数据更容易。GeoPandas 扩展了 pandas 使用的数据类型,以允许对几何类型进行空间运算。几何 操作由 Shapely 执行。Geopandas 进一步依赖 fiona 进行文件访问,并依赖 matplotlib 进行绘图。

  1. 官网地址:GeoPandas 0.dev+untagged — GeoPandas 0+untagged.50.g9a9f097.dirty 文档

  2. 在这里插入图片描述

  3. 成熟社区

  • GIS Stack Exchange

GIS Stack Exchange 是专注于地理信息系统的问答社区。您可以在这里找到与 GeoPandas 相关的问题和答案,涉及地理空间数据处理、地图绘制、坐标转换等方面。

网址为:https://gis.stackexchange.com/

  • GitHubStack Overflow

GeoPandas 的 GitHub 仓库是这个:https://github.com/geopandas/geopandas

这个仓库是 GeoPandas 项目的官方代码托管地点,您可以在这里找到 GeoPandas 的源代码、问题追踪、合并请求以及开发者讨论。如果您对贡献代码、报告问题或者了解 GeoPandas 的最新开发进展感兴趣,这个仓库将会是一个重要的参考资源。

在这个仓库中,您可以找到 GeoPandas 的代码库、开发文档、贡献指南等信息。同时,您也可以在 Issues 页面中报告 bug、提出功能请求,或者在 Pull Requests 页面中参与代码的贡献和讨论。

通过 GitHub 仓库,您可以与 GeoPandas 社区中的开发者和其他用户进行交流、分享想法,并参与到 GeoPandas 的持续发展和改进中。
在这里插入图片描述

1. GeoPandas的核心概念

GeoPandas 是一个用于处理地理空间数据的 Python 库,它构建在许多其他库的基础之上,主要是 Pandas、Shapely 和 Fiona。以下是 GeoPandas 中的一些核心概念:

  1. GeoSeries 和 GeoDataFrame: 这两个数据结构是 GeoPandas 的核心。它们分别是基于 Pandas 的 Series 和 DataFrame,但增加了对地理空间数据的支持。GeoSeries 是一维的数据结构,类似于 Pandas 的 Series,但其元素是几何对象。GeoDataFrame 类似于 Pandas 的 DataFrame,但至少包含一个列是 GeoSeries,表示几何数据。

  2. 几何对象: GeoPandas 支持几何对象,比如点(Point)、线(LineString)、多边形(Polygon)等。这些几何对象可以储存在 GeoSeries 中,并允许执行各种空间分析和操作。

  3. 地理空间数据的操作: GeoPandas 提供了各种地理空间数据操作,例如缓冲区分析、空间查询、几何对象的交集、并集等。

  4. 读取和写入地理空间数据: GeoPandas 支持读取和写入多种地理空间数据格式,如 ESRI Shapefile、GeoJSON、GeoPackage 等,以及与其他 GIS 软件兼容的格式。

  5. 地理空间操作函数: GeoPandas 结合了 Shapely 库的功能,可以进行一系列的空间操作,包括距离计算、几何对象的交叉判断、几何对象的缓冲区生成等。

  6. 地图绘制和可视化: GeoPandas 结合了 Matplotlib 的功能,可以直接从 GeoDataFrame 中绘制地图,显示地理空间数据的可视化结果。

这些概念构成了 GeoPandas 的基本构架和核心功能。借助这些特性,GeoPandas 提供了一个便捷而强大的工具,用于处理和分析地理空间数据,并能够与其他 Python 数据科学和地理信息系统 (GIS) 工具很好地整合。

2. 安装使用GeoPandas

在 Windows 上安装 GeoPandas 并在 Jupyter Notebook 中使用,您可以按照以下步骤操作:

步骤一:安装 Python

如果您尚未安装 Python,请从 Python 官网 下载并安装最新版本的 Python。在安装过程中,请确保勾选“Add Python to PATH”选项,以便在命令行中访问 Python。

步骤二:安装依赖工具

1. 安装 Visual C++ Build Tools

GeoPandas 和其依赖项中的部分库可能需要编译 C/C++ 扩展。在 Windows 上,您可能需要安装 Visual C++ Build Tools。您可以从 Visual Studio Build Tools 下载并安装适用于您系统的 Visual C++ Build Tools。

2. 安装 GDAL、Fiona、Rtree 和 Pyproj

打开命令提示符(Command Prompt)或 PowerShell,并执行以下命令来安装 GeoPandas 的一些依赖项:

pip install wheel
pip install GDAL Fiona Rtree Pyproj

步骤三:安装 GeoPandas 和 Jupyter Notebook

  1. 打开命令提示符(Command Prompt)或 PowerShell。

  2. 执行以下命令安装 GeoPandas 和 Jupyter Notebook:

pip install geopandas
pip install jupyterlab

步骤四:启动 Jupyter Notebook

  1. 在命令提示符(Command Prompt)或 PowerShell 中,导航到您想要工作的目录。

  2. 启动 Jupyter Notebook,输入以下命令并按 Enter:

jupyter notebook

这将在默认浏览器中打开 Jupyter Notebook,并允许您创建新的 Python Notebook。在 Notebook 中,您可以导入 GeoPandas 并开始使用它进行地理空间数据分析和操作。例如:

import geopandas as gpd# 如果没有报错,表示成功导入 GeoPandas

这些步骤将在 Windows 系统上帮助您安装 GeoPandas 并在 Jupyter Notebook 中使用它。如果遇到任何问题,请随时在这里咨询。

此处有坑

会出现本机电脑安装了python,而Jupyter Notebook中会自带一个Python,所以需要在Jupyter的Kernel中创建并切换

在这里插入图片描述

首先需要找到需要使用python主环境

C:\Python39\python.exe -m pip install ipykernelC:\Python39\python.exe -m ipykernel install --user --name myenv --display-name "Python 3.9 (myenv)"

3. 使用GeoPandas展示一下shp文件

3.1 简单展示一下

import geopandas as gpd# 替换为您的 Shapefile 文件路径
shapefile_path = r'D:\BaiduNetdiskDownload\北京市行政区划\北京市t.shp'
gdf = gpd.read_file(shapefile_path)# 显示加载的地理数据
gdf.plot()

在这里插入图片描述

3.2 展示稍大数据量的矢量shp数据

import geopandas as gpd
import timedef plotShapefile(shapefile_path):# 记录开始时间start_time = time.time()  gdf = gpd.read_file(shapefile_path)end_time = time.time()  # 记录结束时间# 计算执行时间(以秒为单位)execution_time = end_time - start_timeprint("read_file time: {:.4f} seconds".format(execution_time))start_time=end_timegdf.plot()end_time = time.time()  # 记录结束时间# 计算执行时间(以秒为单位)execution_time = end_time - start_timeprint("gdf.plot time: {:.4f} seconds".format(execution_time))plotShapefile(r'D:\BaiduNetdiskDownload\北京市行政区划\北京市t.shp')
plotShapefile(r'D:\BaiduNetdiskDownload\湖北省数据\矢量数据\第二种路网\湖北省_road.shp')

在这里插入图片描述

这篇关于GeoPandas初体验:它是什么,我用它展示一下shp矢量数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/471714

相关文章

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

Python实现数据清洗的18种方法

《Python实现数据清洗的18种方法》本文主要介绍了Python实现数据清洗的18种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录1. 去除字符串两边空格2. 转换数据类型3. 大小写转换4. 移除列表中的重复元素5. 快速统

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

在Pandas中进行数据重命名的方法示例

《在Pandas中进行数据重命名的方法示例》Pandas作为Python中最流行的数据处理库,提供了强大的数据操作功能,其中数据重命名是常见且基础的操作之一,本文将通过简洁明了的讲解和丰富的代码示例,... 目录一、引言二、Pandas rename方法简介三、列名重命名3.1 使用字典进行列名重命名3.编

Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南

《Python使用Pandas库将Excel数据叠加生成新DataFrame的操作指南》在日常数据处理工作中,我们经常需要将不同Excel文档中的数据整合到一个新的DataFrame中,以便进行进一步... 目录一、准备工作二、读取Excel文件三、数据叠加四、处理重复数据(可选)五、保存新DataFram