Python空间数据处理之GDAL读写遥感图像


Posted in Python onAugust 01, 2019

GDAL是空间数据处理的开源包,支持多种数据格式的读写。遥感图像是一种带大地坐标的栅格数据,遥感图像的栅格模型包含以下两部分的内容:

栅格矩阵:由正方形或者矩形栅格点组成,每个栅格点所对应的数值为该点的像元值,在遥感图像中用于表示地物属性值;遥感图像有单波段与多波段,波段表示地物属性的种类,每个波段表示地物一种属性。

大地坐标:空间数据参考表示地图的投影信息;仿射矩阵能将行列坐标映射到面坐标上。

GDAL读写遥感数据的代码:

from osgeo import gdal
import os

class GRID:

  #读图像文件
  def read_img(self,filename):
    dataset=gdal.Open(filename)    #打开文件

    im_width = dataset.RasterXSize  #栅格矩阵的列数
    im_height = dataset.RasterYSize  #栅格矩阵的行数

    im_geotrans = dataset.GetGeoTransform() #仿射矩阵
    im_proj = dataset.GetProjection() #地图投影信息
    im_data = dataset.ReadAsArray(0,0,im_width,im_height) #将数据写成数组,对应栅格矩阵

    del dataset 
    return im_proj,im_geotrans,im_data

  #写文件,以写成tif为例
  def write_img(self,filename,im_proj,im_geotrans,im_data):
    #gdal数据类型包括
    #gdal.GDT_Byte, 
    #gdal .GDT_UInt16, gdal.GDT_Int16, gdal.GDT_UInt32, gdal.GDT_Int32,
    #gdal.GDT_Float32, gdal.GDT_Float64

    #判断栅格数据的数据类型
    if 'int8' in im_data.dtype.name:
      datatype = gdal.GDT_Byte
    elif 'int16' in im_data.dtype.name:
      datatype = gdal.GDT_UInt16
    else:
      datatype = gdal.GDT_Float32

    #判读数组维数
    if len(im_data.shape) == 3:
      im_bands, im_height, im_width = im_data.shape
    else:
      im_bands, (im_height, im_width) = 1,im_data.shape 

    #创建文件
    driver = gdal.GetDriverByName("GTiff")      #数据类型必须有,因为要计算需要多大内存空间
    dataset = driver.Create(filename, im_width, im_height, im_bands, datatype)

    dataset.SetGeoTransform(im_geotrans)       #写入仿射变换参数
    dataset.SetProjection(im_proj)          #写入投影

    if im_bands == 1:
      dataset.GetRasterBand(1).WriteArray(im_data) #写入数组数据
    else:
      for i in range(im_bands):
        dataset.GetRasterBand(i+1).WriteArray(im_data[i])

    del dataset

if __name__ == "__main__":
  os.chdir(r'D:\Python_Practice')            #切换路径到待处理图像所在文件夹
  run = GRID()
  proj,geotrans,data = run.read_img('LC81230402013164LGN00.tif')    #读数据
  print proj
  print geotrans
  print data
  print data.shape
  run.write_img('LC81230402013164LGN00_Rewrite.tif',proj,geotrans,data) #写数据

在GDAL遥感影像读写的基础上,我们可以进行遥感图像的各种公式计算和统计分析。

例如我们所熟知的计算NDVI(归一化植被指数),只要在以上代码倒数第二行中插入代码:

import numpy as np
data = data.astype(np.float)
ndvi = (data[3]-data[2])/(data[3]+data[2])             #3为近红外波段;2为红波段
run.write_img('LC81230402013164LGN00_ndvi.tif',proj,geotrans,ndvi) #写为ndvi图像

当然,这是理想的NDVI,实际处理NDVI还会遇到一些其他要处理的问题。例如NDVI值应该在区间[-1,1]内,但实际中会出现大于1或小于-1的情况,或者某些像点是坏点,出现空值nan,需要进一步的配套处理。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python实现上传下载文件功能
Nov 19 Python
Python网络编程详解
Oct 31 Python
python监控键盘输入实例代码
Feb 09 Python
kaggle+mnist实现手写字体识别
Jul 26 Python
Python爬取商家联系电话以及各种数据的方法
Nov 10 Python
Python实现数据结构线性链表(单链表)算法示例
May 04 Python
Python 网络编程之TCP客户端/服务端功能示例【基于socket套接字】
Oct 12 Python
Python pygame绘制文字制作滚动文字过程解析
Dec 12 Python
virtualenv介绍及简明教程
Jun 23 Python
pytorch 计算Parameter和FLOP的操作
Mar 04 Python
Pytorch 如何实现LSTM时间序列预测
May 17 Python
python数据可视化使用pyfinance分析证券收益示例详解
Nov 20 Python
Python生命游戏实现原理及过程解析(附源代码)
Aug 01 #Python
Python中list的交、并、差集获取方法示例
Aug 01 #Python
详解pandas使用drop_duplicates去除DataFrame重复项参数
Aug 01 #Python
Python使用Pandas对csv文件进行数据处理的方法
Aug 01 #Python
python使用writerows写csv文件产生多余空行的处理方法
Aug 01 #Python
python psutil模块使用方法解析
Aug 01 #Python
python读写csv文件并增加行列的实例代码
Aug 01 #Python
You might like
php+mysqli预处理技术实现添加、修改及删除多条数据的方法
2015/01/30 PHP
PHP创建多级目录的两种方法
2016/10/28 PHP
PHP利用正则表达式将相对路径转成绝对路径的方法示例
2017/02/28 PHP
PHP获取文本框、密码域、按钮的值实例代码
2017/04/19 PHP
基于jQuery实现表格数据的动态添加与统计的代码
2011/01/31 Javascript
jquery click([data],fn)使用方法实例介绍
2013/07/08 Javascript
document.execCommand()的用法小结
2014/01/08 Javascript
Jquery Post处理后不进入回调的原因及解决方法
2014/07/15 Javascript
基于jQuery实现的仿百度首页滑动选项卡效果代码
2015/11/16 Javascript
jquery+php实现滚动的数字特效
2015/11/29 Javascript
基于jquery实现图片放大功能
2016/05/07 Javascript
Nodejs中解决cluster模块的多进程如何共享数据问题
2016/11/10 NodeJs
AngularJS实现给动态生成的元素绑定事件的方法
2016/12/14 Javascript
jQuery实现弹幕效果
2017/02/17 Javascript
在ABP框架中使用BootstrapTable组件的方法
2017/07/31 Javascript
Vue如何实现响应式系统
2018/07/11 Javascript
JavaScript检查数据中是否存在相同的元素(两种方法)
2018/10/07 Javascript
帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)
2019/08/23 Javascript
详解JavaScript执行模型
2020/11/16 Javascript
Python命名空间详解
2014/08/18 Python
详解python中字典的循环遍历的两种方式
2017/02/07 Python
python学习基础之循环import及import过程
2018/04/22 Python
Python爬虫框架Scrapy常用命令总结
2018/07/26 Python
使用celery执行Django串行异步任务的方法步骤
2019/06/06 Python
使用Python OpenCV为CNN增加图像样本的实现
2019/06/10 Python
python 实现将文件或文件夹用相对路径打包为 tar.gz 文件的方法
2019/06/10 Python
在Django下创建项目以及设置settings.py教程
2019/12/03 Python
用CSS3将你的设计带入下个高度
2009/08/08 HTML / CSS
HTML5中的Web Notification桌面通知功能的实现方法
2019/07/29 HTML / CSS
比利时买床:Beter Bed
2017/12/06 全球购物
三分钟演讲稿事例
2014/03/03 职场文书
小学教师培训方案
2014/06/09 职场文书
乡镇党员干部群众路线对照检查材料思想汇报
2014/09/28 职场文书
党员转正申请报告
2015/05/15 职场文书
PHP实现rar解压读取扩展包小结
2021/06/03 PHP
Python接口自动化之文件上传/下载接口详解
2022/04/05 Python