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 09 Python
Python之eval()函数危险性浅析
Jul 03 Python
python使用多进程的实例详解
Sep 19 Python
用Python实现读写锁的示例代码
Nov 05 Python
Python中安装easy_install的方法
Nov 18 Python
如何用C代码给Python写扩展库(Cython)
May 17 Python
python join方法使用详解
Jul 30 Python
Python高级property属性用法实例分析
Nov 19 Python
Python CSV文件模块的使用案例分析
Dec 21 Python
使用sklearn的cross_val_score进行交叉验证实例
Feb 28 Python
Python numpy多维数组实现原理详解
Mar 10 Python
详解基于Jupyter notebooks采用sklearn库实现多元回归方程编程
Mar 25 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
图片存储与浏览一例(Linux+Apache+PHP+MySQL)
2006/10/09 PHP
php上传文件,创建递归目录的实例代码
2013/10/18 PHP
Yii实现单用户博客系统文章详情页插入评论表单的方法
2015/12/28 PHP
一个对于Array的简单扩展
2006/10/03 Javascript
面向对象的编程思想在javascript中的运用上部
2009/11/20 Javascript
鼠标放在图片上显示大图的JS代码
2013/03/26 Javascript
ExtJs默认的字体大小改变的几种方法(自己整理)
2013/04/18 Javascript
jQuery中even选择器的定义和用法
2014/12/23 Javascript
javascript常见数字进制转换实例分析
2016/04/21 Javascript
jqueryMobile 动态添加元素,展示刷新视图的实现方法
2016/05/28 Javascript
再谈javascript常见错误及解决方法
2016/09/16 Javascript
关于json字符串与实体之间的严格验证代码
2016/11/10 Javascript
JS实现无缝循环marquee滚动效果
2017/05/22 Javascript
JS实现移动端判断上拉和下滑功能
2017/08/07 Javascript
easyui下拉框动态级联加载的示例代码
2017/11/29 Javascript
解决vue-router进行build无法正常显示路由页面的问题
2018/03/06 Javascript
mpvue 单文件页面配置详解
2018/12/02 Javascript
在layui tab控件中载入外部html页面的方法
2019/09/04 Javascript
微信小程序中限制激励式视频广告位显示次数(实现思路)
2019/12/06 Javascript
vue element自定义表单验证请求后端接口验证
2019/12/11 Javascript
ES11新增的这9个新特性,你都掌握了吗
2020/10/15 Javascript
[58:12]Ti4第二日主赛事败者组 LGD vs iG 3
2014/07/21 DOTA
Python文件夹与文件的操作实现代码
2014/07/13 Python
21行Python代码实现拼写检查器
2016/01/25 Python
Python编程实现两个文件夹里文件的对比功能示例【包含内容的对比】
2017/06/20 Python
python 定义给定初值或长度的list方法
2018/06/23 Python
django项目登录中使用图片验证码的实现方法
2019/08/15 Python
python爬虫库scrapy简单使用实例详解
2020/02/10 Python
Matplotlib配色之Colormap详解
2021/01/05 Python
皇马官方商城:Real Madrid Store
2016/09/02 全球购物
高中三年学习生活的自我评价
2013/10/10 职场文书
农村婚礼证婚词
2014/01/10 职场文书
党员干部三严三实心得体会
2014/10/13 职场文书
六查六看六改心得体会
2014/10/14 职场文书
导游词之长城八达岭
2019/09/24 职场文书
mybatis 获取更新记录的id
2022/05/20 Java/Android