Python ArcPy批量计算多时相遥感影像的各项元平均值

  本文介绍基于PythonArcPy模块,对大量长时间序列栅格遥感影像文件的每一个像元进行多时序平均值的求取。

  在遥感应用中,我们经常需要对某一景遥感影像中的全部像元的像素值进行平均值求取——这一操作很好实现,基于ArcMap软件或者简单的Python代码就可以实现;但有时候,我们会需要结合同一地区、不同时相多景遥感影像,求取每一个像元全部时相中像素值的平均值——这一需求的实现较之前者就有些麻烦,本文对此加以介绍。

  首先,我们来明确一下本文的具体需求。现有一个存储有大量.tif格式遥感影像的文件夹,其中每一个遥感影像的文件名中都包含有该图像的成像时间,如下图所示。且其中除了.tif格式的遥感影像文件外,还具有其它格式的文件。

Python ArcPy批量计算多时相遥感影像的各项元平均值

  我们希望,对于同一年成像的遥感影像进行逐像元平均值的求取。例如,上图中具有2001年第185天成像、第193天成像、第201天成像……等等遥感影像8幅,每一幅都是这一年不同时间在同一空间位置的成像;同时,还有2005年不同时间成像的遥感影像9幅。我们希望,首先将2001年成像的8幅遥感影像加以逐像元平均值的求取,即求取每一个像元在这8景图像中像素值的平均;随后再对2005年成像的9幅遥感影像加以逐像元平均值的求取,以此类推。

  明确了需求后,我们就可以开始具体的操作。首先,本文所需用到的代码如下。

# -*- coding: utf-8 -*-
"""
Created on Sat Apr 16 10:48:37 2022

@author: fkxxgis
"""

import arcpy
from arcpy.sa import *

tif_file_path="E:/LST/Data/MODIS/05_Resample/"
average_file_path="E:/LST/Data/MODIS/06_Average/"
arcpy.env.workspace=tif_file_path

tif_file_name=arcpy.ListRasters("*","tif")
tif_file_year=tif_file_name[0][0:4]
one_year_tif_list=[]
sum_pic=0

for tif_file in tif_file_name:
    if tif_file[0:4]==tif_file_year:
        one_year_tif_list.append(tif_file)
        tif_file_temp=tif_file
        if tif_file==tif_file_name[len(tif_file_name)-1]:
            pic_num=len(one_year_tif_list)
            for tif_file_new in one_year_tif_list:
                sum_pic=sum_pic+Raster(tif_file_new)
            (sum_pic/pic_num).save(average_file_path+tif_file_year+"_Ave.tif")
    else:
        pic_num=len(one_year_tif_list)
        for tif_file_new in one_year_tif_list:
            sum_pic=sum_pic+Raster(tif_file_new)
        (sum_pic/pic_num).save(average_file_path+tif_file_year+"_Ave.tif")
        one_year_tif_list=[]
        sum_pic=0
        one_year_tif_list.append(tif_file)
        tif_file_year=tif_file[0:4]

  其中,tif_file_path是原有计算平均值前遥感图像的保存路径,average_file_path是我们新生成的求取平均值后遥感影像的保存路径,也就是结果保存路径。

  在这里,和我们前期的博客Python ArcPy批量拼接长时间序列栅格图像类似,需要首先在资源管理器中,将tif_file_path路径下的各文件以“名称”排序的方式进行排序;随后,利用arcpy.ListRasters()函数,获取路径下原有的全部.tif格式的图像文件,并截取第一个文件的部分文件名,从而获取其成像时间的具体年份。

  接下来,遍历tif_file_path路径下全部.tif格式图像文件。其中,我们通过一个简单的判断语句if tif_file[0:4]==tif_file_year:,来确定某一年的遥感影像是否已经读取完毕——如果已经读取完毕,例如假如2001年成像的8幅遥感影像都已经遍历过了,那么就对这8景遥感影像加以逐像元的平均值求取,并开始对下一个年份(即2005年)成像的遥感影像继续加以计算;如果还没有读取完毕,例如假如2001年成像的8幅遥感影像目前仅遍历到了第5幅,那么就不求平均值,继续往下遍历,直到遍历完2001年成像的8幅遥感影像。

  这里相信大家也看到了为什么我们要在前期先将文件夹中的文件按照“名称”排序——是为了保证同一年成像的所有遥感影像都排列在一起,遍历时只要遇到一个新的年份,程序就知道上一个年份的所有图像都已经遍历完毕了,就可以将上一个年份的所有栅格图像加以平均值求取。

  在这里,逐像元的平均值求取其实也非常简单——我们对每一个像元分别执行以下操作:首先将该像元在当前年份里所有遥感影像的像素值相加,随后除以这一年份的遥感影像的数量,得到的就是该像元在这一年中像素值的平均值

  最后,通过if tif_file==tif_file_name[len(tif_file_name)-1]:这个判断,来确认是否目前已经遍历到文件夹中的最后一个图像文件。如果是的话,就需要将当前成像年份的所有图像进行平均值的求取,并宣告代码完成运行。

  在 IDLE (Python GUI) 中运行代码。代码运行完毕后,我们看一下结果文件夹。可以看到,其中的图像已经是按照成像时间,分别完成平均值求取后的结果了。

Python ArcPy批量计算多时相遥感影像的各项元平均值

  在最后,还需要说明一点——用以上代码来求取长时间序列遥感影像的像元平均值,对于任意一个像元,只要该像元在任意一个时相的图像中是无效值(即为NoData),那么该像元在最终求出的平均值结果图中,像素值也将会是无效值NoData。针对这一问题的解决,我们将在下一篇博客中介绍。

原文链接:https://www.cnblogs.com/fkxxgis/p/17330411.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Python ArcPy批量计算多时相遥感影像的各项元平均值 - Python技术站

(0)
上一篇 2023年4月19日
下一篇 2023年4月19日

相关文章

  • Python语法概念基础详解

    让我详细讲解一下“Python语法概念基础详解”的攻略。 一、Python语法概念基础 1. 注释 Python中的注释以 # 开头,可以单独一行或者在代码行的末尾进行注释。注释是给读者阅读代码带来的额外解释,不会对程序的执行产生影响。 # 这是单行注释 x = 1 # 这是对变量x进行注释 2. 变量 Python中的变量是动态类型的,也就是说在定义变量时…

    python 2023年5月13日
    00
  • Python+PyQt5+MySQL实现天气管理系统

    下面是Python+PyQt5+MySQL实现天气管理系统的完整攻略: 1. 实现思路 天气管理系统需要实现以下功能: 查看天气信息:用户输入城市名称后,系统从数据库中查询该城市的天气信息,并返回给用户; 添加天气信息:管理员在系统中添加新的天气信息,包括城市名称、天气情况、温度等信息; 修改天气信息:管理员可以修改已经添加的天气信息; 删除天气信息:管理员…

    python 2023年5月30日
    00
  • Python prettytable模块应用详解

    Python prettytable模块应用详解 prettytable是Python中一个用于创建漂亮的表格的模块,可以将数据以表格的形式展示出来,支持排序、格式化等功能。本文将详细介绍prettytable模块的使用方法,并提供示例代码。 安装 可以使用pip命令安装prettytable模块: pip install prettytable 基本用法 …

    python 2023年5月15日
    00
  • 使用Python批量对文本文件编码互转的方法

    当我们需要对大量文本文件进行编码转换时,手动一个一个转换是非常费时费力的。Python提供了很多强大的库,可以方便地批量处理文本文件编码转换。本篇攻略将详细介绍如何使用Python实现批量对文本文件进行编码互转的方法。 1. 安装必要的库 在使用Python进行编码转换前,我们需要先安装必要的库。在这里我们使用 chardet 与 iconv 两个库,这两个…

    python 2023年5月20日
    00
  • Python中获取绝对文件路径的目录路径

    【问题标题】:Get the directory path of absolute file path in PythonPython中获取绝对文件路径的目录路径 【发布时间】:2023-04-05 04:56:01 【问题描述】: 我想获取文件所在的目录。例如完整路径为: fullpath = “/absolute/path/to/file” # some…

    Python开发 2023年4月5日
    00
  • Python标准库sys库常用功能详解

    Python标准库sys库常用功能详解 简介 Python标准库sys库是Python自带的一个系统参数相关的库,通过它可以访问与Python解释器相关的系统参数和函数。它包含了与Python解释器进行交互的一系列工具,主要包括: sys.argv:获取命令行参数 sys.path:获取Python模块搜索路径 sys.modules:获取已经加载的模块 s…

    python 2023年5月30日
    00
  • 利用PyQt中的QThread类实现多线程

    利用PyQt中的QThread类实现多线程的攻略包括以下几个步骤: 导入必要的库 from PyQt5.QtCore import QThread, pyqtSignal 创建一个继承自QThread类的自定义线程类,并重写run()方法用于执行线程任务 class MyThread(QThread): # 自定义信号,用于将线程任务执行结果传递给主线程 u…

    python 2023年5月19日
    00
  • python读取测试数据的多种方式

    Python读取测试数据可以用多种方式,下面给出几种示例: 从文件读取数据 使用open函数读取txt文件 可以使用Python内置的open函数读取txt格式的数据,如下所示: with open("test.txt", "r") as f: data = f.read() 上述代码使用了with语句自动关闭文件,用…

    python 2023年6月3日
    00
合作推广
合作推广
分享本页
返回顶部