Python:使用GDAL读写栅格数据/影像

Python有许多的库可以用来读写栅格数据,比如常见的GDAL、rasterio等,这里介绍一下如何使用GDAL来读写栅格数据,把读写栅格数据分别封装成了两个函数,直接复制使用即可:

读取栅格数据:

python 复制代码
from osgeo import gdal
from osgeo import ogr
from osgeo import osr
import numpy as np
# read data: nodata -> 0
def ReadData(filepath):  # 输入文件路径,tif格式
    gdal.AllRegister()
    ds = gdal.Open(filepath)
    clos = ds.RasterXSize  # 列数
    rows = ds.RasterYSize  # 行数
    bands = ds.RasterCount  # 波段数
    geotrans = ds.GetGeoTransform()  # 坐标系基准
    proj = ds.GetProjection()  # 投影
    data = ds.ReadAsArray() 
    data[data == data[0,0]] = 0  # nodata转为0,这里可以自己设置
    return [clos, rows, data, geotrans, proj]

写出栅格数据:

python 复制代码
def Write2Tiff(newpath,im_data,im_geotrans,im_proj):  # 输入写出路径;写出数据;写出数据的基准;投影
    if 'int8' in im_data.dtype.name:
        datatype = gdal.GDT_Int16
    elif 'int16' in im_data.dtype.name:
        datatype = gdal.GDT_Int16
    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')
    new_data = driver.Create(newpath, im_width, im_height, im_bands, datatype)
    new_data.SetGeoTransform(im_geotrans)
    new_data.SetProjection(im_proj)
    if im_bands == 1:
        new_data.GetRasterBand(1).WriteArray(im_data)
    else:
        for i in range(im_bands):
            new_data.GetRasterBand(i+1).WriteArray(im_data[i])
    del new_data

以上就是关于如何使用GDAL读写栅格数据。

更多内容关注公众号【GISerQ】

相关推荐
相醉为友4 分钟前
005 MATLAB符号微积分
开发语言·matlab
东方佑5 分钟前
HtmX 表达的创建和交互
python
蚰蜒螟7 分钟前
openjdk17 jvm 对象 内存溢出 在C++源码体现
开发语言·jvm·c++
爱吃零食的白糖8 分钟前
QT的exec函数
开发语言·qt
湫ccc27 分钟前
《Python基础》之Python中可以转换成json数据类型的数据
python·json
大今野31 分钟前
JavaScript习题练习
开发语言·javascript·ecmascript
奔跑草-34 分钟前
【前端】Next.js 服务器端渲染(SSR)与客户端渲染(CSR)的最佳实践
开发语言·前端·javascript·react.js·reactjs
Zilliz Planet40 分钟前
Milvus 2.5:全文检索上线,标量过滤提速,易用性再突破!
后端·python·django·全文检索·milvus
幽兰的天空1 小时前
Java 基础之 List 深度探秘
java·linux·开发语言·windows
小丁爱养花1 小时前
网络原理(二):HTTP 请求 - 首行 => 请求方法 & URL & 版本号
开发语言·网络·网络协议·http