【Pyhton】多年dat数据波段合成为一个dat

我有一个文件夹,内有1961-2020年逐年平均气温栅格数据,格式为dat,dat文件不是以年份命名的,而是一长串名字的最后4位是年份,现在我要对所有年份进行波段合成,合成一个dat,dat每个波段为不同年份的数据,且波段顺序按照年份排列,生成的dat文件能够在ENVI中打开。

import os
from osgeo import gdal

# 设置工作目录和输出文件路径
input_folder = r"D:\itm\平均气温"
output_file = r"D:\itm\平均气温.dat"

# 创建一个列表用于存储每年的栅格数据路径
input_files = []

# 遍历文件夹内的文件
for file in os.listdir(input_folder):
    if file.endswith(".dat"):
        file_path = os.path.join(input_folder, file)
        input_files.append(file_path)

# 对文件进行按年份排序
input_files.sort(key=lambda x: int(x[-8:-4])) # 根据你文件命名的年份位置进行调整

# 创建虚拟栅格
vrt_options = gdal.BuildVRTOptions(separate=True)  # 设置为separate以确保每个文件都在单独的波段中
vrt_file = output_file + ".vrt"
gdal.BuildVRT(vrt_file, input_files, options=vrt_options)

# 打开虚拟栅格
vrt_dataset = gdal.Open(vrt_file)

if vrt_dataset is not None:
    # 创建输出栅格
    driver = gdal.GetDriverByName("ENVI")
    output_dataset = driver.Create(output_file, vrt_dataset.RasterXSize, vrt_dataset.RasterYSize, len(input_files), gdal.GDT_Float32)

    # 将每年的数据按顺序写入对应的波段
    for i, file_path in enumerate(input_files):
        year = file_path[-8:-4]  # 从文件路径中提取年份
        band = vrt_dataset.GetRasterBand(i + 1)
        output_band = output_dataset.GetRasterBand(i + 1)
        output_band.WriteArray(band.ReadAsArray())
        output_band.SetDescription(year)  # 设置波段描述为年份
        output_band.SetNoDataValue(9999)  # 设置无效值
        output_band.FlushCache()


    # 设置地理参考信息
    output_dataset.SetGeoTransform(vrt_dataset.GetGeoTransform())
    output_dataset.SetProjection(vrt_dataset.GetProjection())

    # 关闭数据集
    vrt_dataset = None
    output_dataset = None

    os.remove(vrt_file)  # 删除虚拟栅格文件
else:
    print(f"Failed to open the virtual raster file: {vrt_file}")
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值