5个用于地理空间数据分析的Python包

news2024/11/27 6:24:51

大家好,地理空间数据分析在城市规划、环境研究、农业和交通等行业中至关重要。不断增长的需求导致Python包在各种地理数据分析要求上的使用增加,例如分析气候模式、研究城市发展或跟踪疾病传播等,评估和选择具有快速处理、修改和可视化能力的正确工具对于有效分析和可视化地理空间数据至关重要。

首先,了解什么是地理空间数据至关重要。地理空间数据是具有地理成分的数据,表示地球表面上对象、特征或事件的位置和特性。它描述了物理宇宙中各种物体的空间连接、分布和属性。地理空间数据主要有两种类型:

  • 栅格数据(Raster data):适用于没有固定边界的连续信息,表示为具有值的单元格网格,这些值表示观察到的特征。通常在固定的时间间隔上进行监测,并进行插值以创建连续表面。

  • 矢量数据(Vector data):使用点、线和多边形来表示空间属性,包括兴趣点、交通网络、行政边界和土地地块等,通常用于具有精确位置或硬约束的离散数据。

地理空间数据可以以多种格式存储,如 ESRI Shapefile、GeoJSON、Erdas Imagine Image File Format(EIF)、GeoTIFF、Geopackage(GPKG)、GeoJSON、Light Detection、Ranging(LiDAR)等。

地理空间数据涵盖了各种类型,例如卫星图像、高程模型、点云、土地利用分类和基于文本的信息,为跨行业的空间分析和决策提供了有价值的洞察,微软、谷歌、Esri和亚马逊网络服务等大型公司都利用地理空间数据来获得有价值的洞察。接下来一起了解一下地理空间数据分析的五大Python包,这些包能够进行数据读取/写入、操作、可视化、地理编码和地理索引,适用于初学者和有经验的用户,为地理空间数据的有效探索、可视化和洞察提供支持。

1. Geopandas

适用于:矢量数据

Geopandas是一个广泛使用的Python库,用于处理矢量地理空间数据,在Pandas DataFrames中提供直观的地理数据处理,它支持Shapefile和GeoJSON等格式,并提供合并、分组和空间连接等空间操作。Geopandas可以与流行的库(如Pandas、NumPy和Matplotlib等)无缝集成,它可以处理大型数据集,但这可能带来挑战。Geopandas包通常用于空间数据分析任务,包括空间连接、查询以及缓冲区和交叉分析等地理空间操作,需要使用不同的包,如Shapely处理几何操作,Fiona访问文件,以及matplotlib绘图。

例如,可以使用Geopandas来探索房地产数据,以确定城市中最昂贵的街区,或者分析人口数据以可视化不同社区的增长和迁移模式。

可以使用以下pip命令安装该包:

pip install geopandas

使用GeoPandas进行绘图,通过以下代码查看内置地图:

import geopandas 
# 检查可用地图
geopandas.datasets.available

本文将使用GeoPandas加载世界地图数据集,提取美国的形状文件,并使用以下代码将其绘制在图表上:

# 选择特定地图
geopandas.datasets.get_path('naturalearth_lowres')
# 打开所选地图-GeoDataFrame
world = geopandas.read_file(geopandas.datasets.get_path('naturalearth_lowres'))
# 创建GeoDataFrame的子集
usa = world[world.name == "United States of America"]
# 绘制子集
usa.plot();

以上代码将打印出一个子集数据框的地图:

图片

2. Folium

适用于:点云

Folium是一个用于创建带有标记、弹出式窗口、choropleth和其他地理空间可视化的Python库,它与Leaflet JavaScript库集成,并允许将地图导出为HTML。并且可以与Geopandas和Cartopy结合使用,并使用Map Tiles处理大型数据集。Folium在简洁性、美观性以及与其他地理空间库的集成方面表现出色,然而对于高级地理空间分析和操作,Folium可能存在一些局限性。

例如,Folium可用于供应链和物流领域,用于可视化分销网络、优化路线和监测货物位置及装运地点。可以使用以下命令安装Folium:

pip install folium

现在可以使用以下几行代码在以[0, 0]为中心的示例交互式地图上放置一个标记:

import folium
# 以中心坐标(0, 0)生成Folium地图
map = folium.Map(location=[0, 0], zoom_start=2)
# 定位坐标(0, 0)
folium.Marker([0, 0]).add_to(map)
# 显示地图
map

图片

可以根据特定的地理空间数据进一步自定义此地图,例如添加标记、图层或样式选项。

3. ipyleaflet

适用于:点云,交互式

ipyleaflet包能够在Python中轻松创建交互式地图,特别适用于Jupyter笔记本,在其中允许用户生成和共享具有各种底图、标记和其他地理空间操作的交互式地图。ipyleaflet基于Leaflet JavaScript库构建,支持GeoJSON和WMS图层、CSS和JavaScript样式以及地理空间计算。虽然ipyleaflet在交互式小部件方面表现出色,但由于其依赖于JavaScript,对于纯Python项目可能不是理想选择。

例如,ipyleaflet可以应用于环境监测,以可视化传感器数据、监测空气质量并实时评估环境变化。要安装ipyleaflet,可以使用以下pip命令:

pip install ipyleaflet

使用ipyleaflet绘图,用以下代码在地图上创建一个标记,该标记位于纽约市的坐标(40.7128,-74.0060)处,以表示感兴趣的点:

from ipyleaflet import Map, Marker
# 创建地图
m = Map(center=(40.7128, -74.0060), zoom=12)
# 添加标记
marker = Marker(location=(40.7128, -74.0060))
m.add_layer(marker)

以下是代码的输出结果:

图片

4. Rasterio

适用于:栅格数据

Rasterio是一个功能强大的Python库,用于处理地理空间栅格数据,具有高效的性能和广泛的操作,如裁剪、重投影和重采样。它支持各种栅格格式,并与其他地理空间库良好集成,尽管在处理矢量数据和复杂分析任务方面存在一些限制。然而,Rasterio是Python中高效操作和处理栅格数据的必备工具。

例如,Rasterio可用于读取和写入卫星图像、进行地形分析、从数字高程模型中提取数据以及进行遥感分析等任务。

!pip install rasterio

rasterio.open()函数用于打开文件,read()方法将图像读取为NumPy数组。最后,使用Matplotlib中的plt.imshow()函数显示图像,plt.show()在输出中显示绘图。

import rasterio
from rasterio.plot import show

使用rasterio库打开并可视化来自kaggle数据集“High-resolution GeoTIFF images of climatic data”中的sample.tif文件的栅格图像,将红色通道(图像中的一种颜色通道)作为子图使用Reds颜色映射进行显示,将原始图像(包含多个颜色通道)作为另一个子图使用viridis颜色映射进行显示。也可以使用相同的方法可视化其他颜色通道,如绿色和蓝色。

src = rasterio.open('/content/sample.tif')
plt.figure(figsize=(15,10))
fig, (axr, axg) = plt.subplots(1,2, figsize=(15,7))
show((src, 1), ax=axr, cmap='Reds', title='red channel')
show((src), ax=axg, cmap='viridis', title='original image')
plt.show()

图片

原始GeoTIFF图像(右)来源:Kaggle.com

https://www.kaggle.com/datasets/abireltaief/highresolution-geotiff-images-of-climatic-data

在地理空间分析中,分析特定的颜色通道(如红色、蓝色和绿色)是为了关注或提取与图像中那些颜色分量相关的特定属性、特征或特征所表示的有价值信息,可以用于遥感中的植被健康、植被指数或水体等方面。

5. Geoplot

适用于:矢量数据,交互式

Geoplot是一个用户友好型的Python库,可以快速创建具有吸引力的地理空间可视化效果,包括等值线地图和散点图,它与流行的数据处理库(如Pandas等)无缝集成,并支持多种地图投影。然而,Geoplot在交互式地图支持和绘图类型方面存在一些限制,比专门的地理空间库要少。尽管如此,它仍然对于快速实现地理空间数据可视化和获取空间模式的洞察力非常有价值。

!pip install geoplot

本文将使用Geoplot绘制一个等值图可视化,根据世界形状文件中的“continent”属性选择亚洲国家,根据“pop_est”属性分配颜色强度,并使用带图例的“icefire”彩色地图进行绘制,图例的尺寸大小为10x5。

import geoplot
# 绘制亚洲人口分布图
asia = world.query("continent == 'Asia'")
geoplot.choropleth(asia, hue = "pop_est", cmap = "icefire",legend=True, figsize = (10, 5));

图片

例如,geoplot包可以创建choropleth地图,用于可视化人口密度、绘制犯罪事件的空间模式、显示环境因素的分布,并根据地理数据分析疾病的传播。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1213150.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Leetcode2652. 倍数求和

Every day a Leetcode 题目来源:2652. 倍数求和 解法1:模拟 计算在 [1,n] 范围内能被 3、5、7 整除的所有整数之和。 代码: /** lc appleetcode.cn id2652 langcpp** [2652] 倍数求和*/// lc codestart class Solution { pu…

【Nginx】使用nginx进行反向代理与负载均衡

使用场景 反向代理:一个网站由许多服务器承载的,网站只暴露一个域名,那么这个域名指向一个代理服务器ip,然后由这台代理服务器转发请求到网站负载的多台服务器中的一台处理。这就需要用到Nginx的反向代理实现了 负载均衡&#xf…

LOWORD, HIWORD, LOBYTE, HIBYTE的解释

文章目录 实验结论 实验 int 类型大小正常为4Byte 以小端序来看 0x12345678在内存中的存储为 0x78 0x56 0x34 0x120x78在低地址&#xff0c;0x12在高地址 程序输出 #include <stdio.h> #include <string.h> #include<windows.h>int main() {int a 0x12345…

第四代管网水位监测仪:管网水位监测仪使用方法

排水管网水位监测是城市管理的重要环节之一&#xff0c;城市管理部门一直都想要确保排水管网的正常运行&#xff0c;以此促进城市的发展和智慧城市的建设。想要依靠人工对城市排水管网设施进行检修是一个大工程&#xff0c;不仅要耗费大量的人工和时间成本&#xff0c;还有可能…

《QT从基础到进阶·二十七》进度条QProgressBar

ui.ProgressBar.setValue(45); //45% ui.ProgressBar.setMin(0); ui.ProgressBar.setMax(255);0到100分为255份&#xff0c;值为215时&#xff0c;进度条为100/255*215 84% 点击主界面弹出进度条QProgressDialog 常用功能&#xff1a; setWindowFlags(Qt::Dialog | Qt::Cu…

沉醉于代码的境界:探寻计算机书籍的奇妙之旅

文章目录 书中的代码乐章科技解密的乐趣技术指南的引路明灯书籍带给我的启示结语 &#x1f389;欢迎来到数据结构学习专栏~沉醉于代码的境界&#xff1a;探寻计算机书籍的奇妙之旅 ☆* o(≧▽≦)o *☆嗨~我是IT陈寒&#x1f379;✨博客主页&#xff1a;IT陈寒的博客&#x1f38…

掌握Python中的控制流语句:break, continue, quit的应用技巧详解

引言 在Python编程中&#xff0c;控制流语句是非常重要的一部分&#xff0c;它们可以帮助我们控制程序的执行流程。其中&#xff0c;break、continue和quit是常用的控制流语句&#xff0c;它们可以在循环中起到关键作用。本文将详细介绍这些控制流语句的应用技巧&#xff0c;帮…

无烟火焰:探索酒精壁炉的魅力

随着技术的不断发展&#xff0c;现代生活的很多方面都发生了变化&#xff0c;包括我们如何取暖和装饰我们的家。酒精壁炉是一个迅速崭露头角的家居装饰方式&#xff0c;为家庭带来了一种别具一格的现代化火焰体验。 过去&#xff0c;我们可能依赖于传统的木材壁炉或煤气取暖系统…

无线终端掉线问题专题

一、终端连接过程 1、通过beacon或者probe帧发现设备 2、accoc和auth过程 3、EAP过程 4、DHCP过程 5、portal过程 6、终端检测wlan是否可以上网 7、正常接入网络 二、终端无法上网 终端无法上网则说明终端在连接过程中某一个环节除了问题 1、发现AP过程&#xff0c;p…

零成本体验美国云服务器,更方便的体验和选择

在当今数字化时代&#xff0c;云计算已经成为了企业和个人的首选。而美国云服务器免费试用&#xff0c;则为广大用户提供了一个零风险尝试的机会。作为一种高效、灵活、稳定的解决方案&#xff0c;美国云服务器可以为您的业务保驾护航。 什么是美国云服务器&#xff1f; 美国云…

CFCA国密证书

CFCA是中国金融认证中心的缩写&#xff0c;即China Financial Certification Authority。它是一家经过中国人民银行和国家信息安全机构批准成立的国家级权威安全认证机构&#xff0c;也是国际CA浏览器联盟组织&#xff08;CA/Browser Forum&#xff09;的成员&#xff0c;遵循全…

【Unity】Unity开发微信小游戏(三)工具使用Instant Game

Instant Game窗口通过Window->Auto Streaming打开。 也可参考官方详细说明 1.Texture Streaming 配置游戏内texture是否使用streaming功能&#xff0c;以及streaming placeholder的类型。AutoStreaming用placeholder图片替换游戏首包内的原始贴图&#xff0c;游戏运行时&a…

JavaScript语法、语句、数据类型

一、JavaScript语法&#xff1a; 1、JavaScript字面量&#xff1a; JavaScript中的固定值称为字面量。数字字面量可以是整数、小数或者科学计数&#xff08;e&#xff09;,如3.1415926、1008、123e5等&#xff1b;字符串字面量可以使用单引号或者双引号&#xff0c;如“corli…

第四代内涝积水监测仪:城市内涝积水监测仪厂家直销

城市内涝频发&#xff0c;导致居民被迫迁离家园&#xff0c;前往其他安全区域&#xff1b;同时&#xff0c;城市基础设施受损&#xff0c;引发各种安全隐患。此外&#xff0c;淤泥在城市各处堆积&#xff0c;可能产生病毒和细菌&#xff0c;对公共卫生造成威胁。 每个城市都在为…

ctfshow 文件上传 151-161

文件上传也好久没做了。。 手很生了 151 前端绕过 只能上传png文件 使用bp抓包&#xff0c;修改文件名后缀为php 上传成功&#xff0c;发现文件上传路径 使用蚁剑连接 找到flag 152 152 后端校验 跟上一关一样 表示后面即使执行错误&#xff0c;也不报错 抓包修改文件…

高难度工业废水处理有哪些注意事项

高难度工业废水处理的注意事项包括&#xff1a; 预处理&#xff1a;在将废水输送至污水处理系统前&#xff0c;应进行预处理&#xff0c;以减轻处理设备的负荷&#xff0c;提高处理效率。预处理可以包括去除废水中的悬浮物、沉淀物以及防止化学物质的沉积等。针对不同废水选择…

如何选择工业以太网交换机?

现在市面上有许多品牌的工业以太网交换机&#xff0c;并且类型也相当复杂。在选择交换机的时候&#xff0c;需要考虑多个因素&#xff0c;比如工作环境、是否需要冗余配置、是否需要网管功能、是否需要非网管功能、以及未来的维护和扩展性等。通常情况下&#xff0c;当选择工业…

requests.post 数据字段编码问题的方法

今夜&#xff0c;我要在代码的海洋中遨游&#xff0c;捕捉那只顽皮的bug。作为一名程序员&#xff0c;不断解决问题是日常的工作。而今天我要解决的是 requests.post 数据字段编码问题。在编程中&#xff0c;数据的编码问题常常让人头疼&#xff0c;它可能会导致程序无法正常运…

比较器应用之一_窗口比较器/极限比较器

窗口比较器&#xff1a;用处能在一个&#xff0c;电压落在规定的范围之内&#xff0c;报警或者不报警 当输入电压u1 > URa时&#xff0c;必然大于UaL&#xff0c;所以集成运放A1的输出uo1Uow&#xff0c;A2的输出u02-Uow。使得二极管D1导通&#xff0c;D2截止&#xff0c;电…

资产跟踪影响利润的 7 种方式

几乎每个工人都被托付某种有形资产来完成他们的工作。根据您的工作领域&#xff0c;这可能是一套制服、徽章、一台电脑、一部工作电话、一套建筑钥匙、一个工具包&#xff0c;甚至是一台价值超过您年薪的机器。 无论如何&#xff0c;我们都熟悉丢失您所保管的物品所带来的压力…