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 相关文章推荐
pymongo实现多结果进行多列排序的方法
May 16 Python
Python实现端口检测的方法
Jul 24 Python
Selenium定位元素操作示例
Aug 10 Python
对python中list的拷贝与numpy的array的拷贝详解
Jan 29 Python
python3 tkinter实现点击一个按钮跳出另一个窗口的方法
Jun 13 Python
使用PyQt4 设置TextEdit背景的方法
Jun 14 Python
python ctypes库2_指定参数类型和返回类型详解
Nov 19 Python
python绘制随机网络图形示例
Nov 21 Python
Python&&GDAL实现NDVI的计算方式
Jan 09 Python
详解用Python爬虫获取百度企业信用中企业基本信息
Jul 02 Python
教你用python实现12306余票查询
Jun 30 Python
如何利用Python实现n*n螺旋矩阵
Jan 18 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中批量删除Mysql中相同前缀的数据表的代码
2011/07/01 PHP
兼容各大浏览器带关闭按钮的漂浮多组图片广告代码
2014/06/05 PHP
ecshop后台编辑器替换成ueditor编辑器
2015/03/03 PHP
分享php分页的功能模块
2015/06/16 PHP
使用Zookeeper分布式部署PHP应用程序
2019/03/15 PHP
Ajax::prototype 源码解读
2007/01/22 Javascript
用JQuery 实现的自定义对话框
2007/03/24 Javascript
Mootools 1.2教程 排序类和方法简介
2009/09/15 Javascript
js 格式化时间日期函数小结
2010/03/20 Javascript
纯Javascript实现Windows 8 Metro风格实现
2013/10/15 Javascript
JQuery中节点遍历方法实例
2015/05/18 Javascript
JavaScript实现自动弹出窗口并自动关闭窗口的方法
2015/08/06 Javascript
jQuery实现产品对比功能附源码下载
2016/08/09 Javascript
jQuery实现简单的抽奖游戏
2017/05/05 jQuery
JavaScript基于面向对象实现的猜拳游戏
2018/01/03 Javascript
Vue封装Swiper实现图片轮播效果
2018/02/06 Javascript
解决vue热替换失效的根本原因
2018/09/19 Javascript
django简单的前后端分离的数据传输实例 axios
2020/05/18 Javascript
[00:55]深扒TI7聊天轮盘语音出处3
2017/05/11 DOTA
[51:15]完美世界DOTA2联赛PWL S2 PXG vs Magma 第一场 11.21
2020/11/24 DOTA
python多线程操作实例
2014/11/21 Python
Python实现压缩与解压gzip大文件的方法
2016/09/18 Python
python实现决策树分类算法
2017/12/21 Python
Python简单实现网页内容抓取功能示例
2018/06/07 Python
解决Pytorch 训练与测试时爆显存(out of memory)的问题
2019/08/20 Python
python mock测试的示例
2020/10/19 Python
HTML5移动端开发中的Viewport标签及相关CSS用法解析
2016/04/15 HTML / CSS
Html5让容器充满屏幕高度或自适应剩余高度的布局实现
2020/05/14 HTML / CSS
意向书范本
2014/07/29 职场文书
会计专业求职信
2014/08/10 职场文书
党员教师四风问题对照检查材料
2014/09/26 职场文书
省级三好学生主要事迹材料
2015/11/03 职场文书
个人业务学习心得体会
2016/01/25 职场文书
创业计划书之香辣虾火锅
2019/09/23 职场文书
ipad隐藏软件app图标方法
2022/04/19 数码科技
Python tensorflow卷积神经Inception V3网络结构
2022/05/06 Python