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远程登录代码
Apr 29 Python
Python中使用platform模块获取系统信息的用法教程
Jul 08 Python
Python简单的制作图片验证码实例
May 31 Python
Python面向对象之继承和多态用法分析
Jun 08 Python
Django REST framework内置路由用法
Jul 26 Python
已安装tensorflow-gpu,但keras无法使用GPU加速的解决
Feb 07 Python
如何通过python实现全排列
Feb 11 Python
Pandas时间序列基础详解(转换,索引,切片)
Feb 26 Python
Tensorflow中k.gradients()和tf.stop_gradient()用法说明
Jun 10 Python
django filter过滤器实现显示某个类型指定字段不同值方式
Jul 16 Python
Python常用模块函数代码汇总解析
Aug 31 Python
Python pymsql模块的使用
Sep 07 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
如何使用脚本模仿登陆过程
2006/11/22 PHP
php实现从ftp服务器上下载文件树到本地电脑的程序
2009/02/10 PHP
PHP Directory 函数的详解
2013/03/07 PHP
PHP读取大文件的多种方法介绍
2016/04/04 PHP
Laravel 实现密码重置功能
2018/02/23 PHP
关于JavaScript中var声明变量作用域的推断
2010/12/16 Javascript
jQuery中的val()示例应用
2014/02/26 Javascript
jQueryMobile之Helloworld与页面切换的方法
2015/02/04 Javascript
JS+CSS实现模仿浏览器网页字符查找功能的方法
2015/02/26 Javascript
jquery实现公告翻滚效果
2015/02/27 Javascript
详述JavaScript实现继承的几种方式(推荐)
2016/03/22 Javascript
js动态获取子复选项并设计全选及提交的实现方法
2016/06/24 Javascript
微信小程序图片选择、上传到服务器、预览(PHP)实现实例
2017/05/11 Javascript
jQuery实现动态删除LI的方法
2017/05/30 jQuery
原生JS实现自定义滚动条效果
2020/10/27 Javascript
vue弹窗消息组件的使用方法
2020/09/24 Javascript
jQuery实现仿京东防抖动菜单效果示例
2018/07/06 jQuery
VUE解决 v-html不能触发点击事件的问题
2019/10/28 Javascript
Vue 数组和对象更新,但是页面没有刷新的解决方式
2019/11/09 Javascript
vue 动态添加的路由页面刷新时失效的原因及解决方案
2021/02/26 Vue.js
[01:08:44]NB vs VP 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
浅析python 中__name__ = '__main__' 的作用
2014/07/05 Python
Python使用正则表达式实现文本替换的方法
2017/04/18 Python
python计算auc指标实例
2017/07/13 Python
详解flask表单提交的两种方式
2018/07/21 Python
Python3.6使用tesseract-ocr的正确方法
2018/10/17 Python
Python正则匹配判断手机号是否合法的方法
2020/12/09 Python
Python实现ATM系统
2020/02/17 Python
python为QT程序添加图标的方法详解
2020/03/09 Python
详解torch.Tensor的4种乘法
2020/09/03 Python
幼儿园中班教学反思
2014/02/10 职场文书
《和田的维吾尔》教学反思
2014/04/14 职场文书
部门群众路线教育实践活动对照检查材料思想汇报
2014/10/07 职场文书
楚门的世界观后感
2015/06/03 职场文书
2019入党申请书格式
2019/06/25 职场文书
祝福语集锦:给满月宝宝的祝福语
2019/11/20 职场文书