用Python进行栅格数据的分区统计和批量提取


Posted in Python onMay 27, 2021

有时候我们会有这样的想法,就是针对某个区域的栅格数据,要提取它的平均值或者其他统计指标,比如在一个省内提取多年的降雨数据,最后分区域地计算一些统计值,或者从多个栅格数据中提取某个区域的数值形成一个序列。为了方便,画一个示意图看看,比如就像提取这个区域中的某一个市的区域,然后形成一个序列数据,这就可以使用rasterstats库了,此外的分区统计也可以用这个库

这个实验使用的数据格式分别是栅格(*.tif)和矢量(.shp),之后的分区统计操作和栅格数据的提取都是源于这两类数据。为了能使用上这个rasterstats库,选择了在google colab平台运行脚本,因为安装库实在是太方便了,在win上老是安装不上的,在google notebook立马就搞定了,而且可以把数据存储到谷歌云盘,直接在notebook中就是可以链接使用的

用Python进行栅格数据的分区统计和批量提取

那么现在就开始做测试,使用的数据就是左侧的栅格和矢量数据集
导入相关的模块

import geopandas as gpd
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import rasterio
import rasterstats
from rasterio.plot import show
# show()方法用来展示栅格图形
from rasterio.plot import show_hist
# 用来展示直方图
import cartopy.crs as ccrs
import cartopy.feature as cfeature
from cartopy.mpl.ticker import LongitudeFormatter, LatitudeFormatter

使用geopandas和rasterio分别读取矢量和栅格数据

# 使用geopandas读取矢量数据
districts = gpd.read_file('/content/drive/MyDrive/Datashpraster/Data/Districts/districts.shp')

# 使用rasterio读取栅格数据,栅格数据和矢量数据的坐标投影需要一致
raster = rasterio.open('/content/drive/MyDrive/Datashpraster/Data/Rainfall Data Rasters/2020-4-1.tif')
# 把矢量数据和栅格数据绘制到一个axis上,这个axis不是坐标轴,而是图形
plt.rcParams['font.family'] = 'Times New Roman'
plt.rcParams['font.size'] = 20

fig, (ax1,ax2) = plt.subplots(1,2,figsize=(15,6))

show(raster, ax=ax1,title='Rainfall')
# 读取进来的矢量数据可以直接调用gpd的plot()方法绘制
districts.plot(ax=ax1, facecolor='None', edgecolor='red')
show_hist(raster,ax=ax2,title='hist')

plt.show()

先绘制一下结果看看

用Python进行栅格数据的分区统计和批量提取

读取栅格数据:

# 提取雨量栅格值到numpy数组
# 遵循GDAL规则从第一波段读取
rainfall_data = raster.read(1)
rainfall_data

用Python进行栅格数据的分区统计和批量提取

开始分区统计:

# 设置坐标变换信息
affine = raster.transform

# 准备开始进行空间分区计算
# 第一个参数是矢量分区,第二个是栅格,第三个是坐标变换信息,第四个是统计均值
avg_rallrain = rasterstats.zonal_stats(districts,rainfall_data,affine=affine,stats=['mean'],geojson_out=True)
# avg_rallrain

# 除了统计平均值之外,还有最大最小值那些

绘制一下,只是一个简单的图形而已

用Python进行栅格数据的分区统计和批量提取

当然第二部分更有意思,就是从多个分散的栅格数据中提取数据形成一个序列

,就是这些tif数据

用Python进行栅格数据的分区统计和批量提取

loop这些栅格数据集:

用Python进行栅格数据的分区统计和批量提取

获得提取到的结果,没错,就是这么一个序列数据,然后就是绘图了

用Python进行栅格数据的分区统计和批量提取

转换数据格式

# 将Date列转为时间型
data['Date'] = pd.to_datetime(data['Date'], infer_datetime_format=True)

# print(data)

data['Date'] = data['Date'].dt.date
print(data)

用Python进行栅格数据的分区统计和批量提取

绘图结果就是简单的图形而已

# 准备绘制图形
fig,(ax1,ax2)= plt.subplots(2,1,figsize=(18,6))
plt.rcParams['font.size'] = 15

data.plot(x='Date', y='Average_RF_Porto', ax=ax1, kind='bar', title='Avg_Rail_Porto')
data.plot(x='Date', y='Average_RF_Faro', ax=ax2, kind='bar', title='Avg_Rail_Faro',color='red')

#自动调整图形的分布
plt.tight_layout()
plt.show()

用Python进行栅格数据的分区统计和批量提取

结果就这样一个序列图,目的就是从栅格提取指定的研究区,然后提取栅格的值,再来绘图

虽然感觉不是那么花里胡哨的图,但这个应该还是比较实用的,特别是大批量提取栅格值的时候。由于在google colab里面操作的步骤比较多,中间可能有省略的地方,但重要的应该都在文中了,当然也可以迁移运用到其他地方,也可以查看一下这个第三方库的教程,比如read(1)是什么意思,官网的docs就写得有,实在是很方便的

以上就是用Python进行栅格数据的分区统计和批量提取的详细内容,更多关于Python 栅格数据的分区统计和批量提取 的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python实现的微信好友数据分析功能示例
Jun 21 Python
python3.6使用urllib完成下载的实例
Dec 19 Python
Python使用ctypes调用C/C++的方法
Jan 29 Python
PyQt5下拉式复选框QComboCheckBox的实例
Jun 25 Python
python tkinter组件摆放方式详解
Sep 16 Python
Python+Appium实现自动化测试的使用步骤
Mar 24 Python
PyQt5连接MySQL及QMYSQL driver not loaded错误解决
Apr 29 Python
Python编写单元测试代码实例
Sep 10 Python
python爬虫---requests库的用法详解
Sep 28 Python
python进行二次方程式计算的实例讲解
Dec 06 Python
教你怎么用Python实现GIF动图的提取及合成
Jun 15 Python
总结几个非常实用的Python库
Jun 26 Python
手把手教你怎么用Python实现zip文件密码的破解
Python基础学习之奇异的GUI对话框
教你使用pyinstaller打包Python教程
Matplotlib绘制混淆矩阵的实现
只需要100行Python代码就可以实现的贪吃蛇小游戏
PyTorch dropout设置训练和测试模式的实现
May 27 #Python
pytorch Dropout过拟合的操作
You might like
压力如何影响浓缩咖啡品质
2021/03/03 咖啡文化
PHP:风雨欲来 路在何方?
2006/10/09 PHP
IE和FireFox(FF)中js和css的不同
2009/04/13 Javascript
javascript的onchange事件与jQuery的change()方法比较
2009/09/28 Javascript
异步加载script的代码
2011/01/12 Javascript
使用jQuery实现图片遮罩半透明坠落遮挡
2015/03/16 Javascript
jQuery使用after()方法在元素后面添加多项内容的方法
2015/03/26 Javascript
jQuery的实例及必知重要的jQuery选择器详解
2016/05/20 Javascript
浅谈js构造函数的方法与原型prototype
2016/07/04 Javascript
js获取form表单所有数据的简单方法
2016/08/18 Javascript
Bootstrap优化站点资源、响应式图片、传送带使用详解3
2016/10/14 Javascript
浅谈angular4实际项目搭建总结
2017/12/01 Javascript
VUE 使用中踩过的坑
2018/02/08 Javascript
使用 vue.js 构建大型单页应用
2018/02/10 Javascript
js实现跳一跳小游戏
2020/07/31 Javascript
python中pass语句用法实例分析
2015/04/30 Python
Pycharm学习教程(3) 代码运行调试
2017/05/03 Python
python自动发微信监控报警
2019/09/06 Python
Python使用Selenium实现淘宝抢单的流程分析
2020/06/23 Python
matplotlib源码解析标题实现(窗口标题,标题,子图标题不同之间的差异)
2021/02/22 Python
前端隐藏出边界内容的实现方法
2016/04/14 HTML / CSS
html5调用app分享功能示例(WebViewJavascriptBridge)
2018/03/21 HTML / CSS
个人应聘自我评价分享
2013/11/18 职场文书
演讲稿怎么写才完美
2014/01/02 职场文书
会议接待欢迎词
2014/01/12 职场文书
大学生的自我鉴定范文
2014/01/21 职场文书
英语自我介绍演讲稿
2014/09/01 职场文书
离婚财产分隔协议书
2014/10/23 职场文书
2015年度个人思想工作总结
2015/04/08 职场文书
少年犯观后感
2015/06/11 职场文书
关于幸福的感言
2015/08/03 职场文书
创业计划书之物流运送
2019/09/17 职场文书
关于考试抄袭的检讨书
2019/11/02 职场文书
2019年消防宣传标语集锦
2019/11/21 职场文书
mongodb数据库迁移变更的解决方案
2021/09/04 MongoDB
Go结合Gin导出Mysql数据到Excel表格
2022/08/05 Golang