Python ArcPy批量計算多時相遙感影像的各項元平均值

来源:https://www.cnblogs.com/fkxxgis/archive/2023/04/18/17330411.html
-Advertisement-
Play Games

本文介紹基於Python中ArcPy模塊,對大量長時間序列柵格遙感影像文件的每一個像元進行多時序平均值的求取。 在遙感應用中,我們經常需要對某一景遙感影像中的全部像元的像素值進行平均值求取——這一操作很好實現,基於ArcMap軟體或者簡單的Python代碼就可以實現;但有時候,我們會需要結合同一地區 ...


  本文介紹基於PythonArcPy模塊,對大量長時間序列柵格遙感影像文件的每一個像元進行多時序平均值的求取。

  在遙感應用中,我們經常需要對某一景遙感影像中的全部像元的像素值進行平均值求取——這一操作很好實現,基於ArcMap軟體或者簡單的Python代碼就可以實現;但有時候,我們會需要結合同一地區、不同時相多景遙感影像,求取每一個像元全部時相中像素值的平均值——這一需求的實現較之前者就有些麻煩,本文對此加以介紹。

  首先,我們來明確一下本文的具體需求。現有一個存儲有大量.tif格式遙感影像的文件夾,其中每一個遙感影像的文件名中都包含有該圖像的成像時間,如下圖所示。且其中除了.tif格式的遙感影像文件外,還具有其它格式的文件。

  我們希望,對於同一年成像的遙感影像進行逐像元平均值的求取。例如,上圖中具有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) 中運行代碼。代碼運行完畢後,我們看一下結果文件夾。可以看到,其中的圖像已經是按照成像時間,分別完成平均值求取後的結果了。

  在最後,還需要說明一點——用以上代碼來求取長時間序列遙感影像的像元平均值,對於任意一個像元,只要該像元在任意一個時相的圖像中是無效值(即為NoData),那麼該像元在最終求出的平均值結果圖中,像素值也將會是無效值NoData。針對這一問題的解決,我們將在下一篇博客中介紹。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 項目介紹&功能實現 1.項目介紹&環境搭建 一個以社交平臺為核心的輕電商項目,功能如下: 簡訊登錄、商戶查詢緩存、優惠券秒殺、達人探店、好友關註、附近的商戶、用戶簽到、UV統計 1.1項目架構 1.2項目環境搭建 1.2.1後端項目搭建 mysql的版本採用5.7及以上版本 (1)首先創建資料庫,需 ...
  • 本文首發於公眾號:Hunter後端 原文鏈接:Django筆記二十四之資料庫函數之比較和轉換函數 這一篇筆記開始介紹幾種資料庫函數,以下是幾種函數及其作用 Cast 轉換類型 Coalesce 優先取值 Greatest 返回較大值 Nullif 值相同返回 None 1、model 準備 這一篇筆 ...
  • 網路分層結構 電腦網路體系大致分為三種,OSI七層模型、TCP/IP四層模型和五層模型。一般面試的時候考察比較多的是五層模型。最全面的Java面試網站 五層模型:應用層、傳輸層、網路層、數據鏈路層、物理層。 應用層:為應用程式提供交互服務。在互聯網中的應用層協議很多,如功能變數名稱系統DNS、HTTP協議 ...
  • 一、哆啦A夢 由於代碼過長,這裡僅顯示部分代碼: from turtle import * import turtle as t from random import * #五軌跡跳躍 def my_goto(x,y): penup() goto(x,y) pendown() def eyes(): ...
  • Go語言流媒體開源項目 LAL 今天發佈了v0.35.4版本。 LAL 項目地址:https://github.com/q191201771/lal 老規矩,簡單介紹一下: ▦ 一. OBS支持RTMP H265推流 新出的標準,一般被稱為enhanced RTMP,OBS新版(29.1+版本,點我 ...
  • 什麼是冒泡排序 冒泡排序(Bubble Sort)也是一種簡單直觀的排序演算法。它重覆地走訪過要排序的數列,一次比較兩個元素,如果他們的順序錯誤就把他們交換過來。走訪數列的工作是重覆地進行直到沒有再需要交換,也就是說該數列已經排序完成。這個演算法的名字由來是因為越小的元素會經由交換慢慢"浮"到數列的頂端 ...
  • 平時開發時的工作的話之主要負責寫代碼就行了,什麼發佈項目啊,好吧不是我們乾的事。在我們的瞭解中打包發佈項目應該不是一個困難的問題。 對,最簡單的方法就行使用直接使用maven插件打包,甚至我們都不需要知道他是怎麼實現的,插件能幫我們將項目打包為一個jar包,然後使用java -jar xx.jar就 ...
  • 使用第三方jar包,完成get/set操作 Lombok,結合特殊的註解,實現setter和getter的自動生成 導入jar包 使用插件Lombok 在類里import 即可使用 import lombok.AllArgsConstructor; import lombok.Data; impor ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...