Python忽略NoData計算多張遙感影像的像元平均值:whitebox庫

来源:https://www.cnblogs.com/fkxxgis/archive/2023/05/15/17402262.html
-Advertisement-
Play Games

本文介紹基於Python中whitebox模塊,對大量長時間序列柵格遙感影像的每一個像元進行忽略NoData值的多時序平均值求取~ ...


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

  在文章Python ArcPy批量計算多時相遙感影像的各像元平均值中,我們介紹了基於PythonArcpy模塊實現多時相遙感影像數據的平均值求取方法。但是這一方法具有一個問題,即對於任意一個像元,只要該像元在任意一個時相的圖像中是無效值(即為NoData),那麼該像元在最終求出的平均值結果圖中像素值也將會是無效值NoData。這就導致在我們最終計算得到的平均值結果圖層中,具有很多空白區域(像素值為NoData的區域)。

  為瞭解決這一問題,這裡我們再介紹一種基於Python中另一個地理空間數據分析庫——whitebox,實現多時像遙感影像數據逐像元平均值的求取方法。

  首先,需要下載並安裝whitebox這一模塊。如果大家電腦中已經有了Anaconda環境,就可以直接按照Python地理分析庫whitebox在Anaconda中的配置這篇文章中介紹的方法下載、安裝whitebox

  本文要實現的需求和文章Python ArcPy批量計算多時相遙感影像的各像元平均值中的一致,這裡就不再贅述。本文所需用到的代碼如下。

# -*- coding: utf-8 -*-
"""
Created on Sun Apr 17 15:04:29 2022

@author: fkxxgis
"""

import glob
from whitebox import WhiteboxTools

tif_file_path="E:/LST/Data/MODIS/test/"
average_file_path="E:/LST/Data/MODIS/06_Average/"

wbt=WhiteboxTools()
wbt.work_dir=tif_file_path

tif_file_name=glob.glob(tif_file_path+"*.tif")
tif_file_year=tif_file_name[0][-18:-14]
one_year_tif_list=[]

for tif_file in tif_file_name:
    if tif_file[-18:-14]==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]:
            wbt.average_overlay(inputs=';'.join(one_year_tif_list),
                                output=average_file_path+tif_file_year+"_Ave.tif")
    else:
        wbt.average_overlay(inputs=';'.join(one_year_tif_list),
                            output=average_file_path+tif_file_year+"_Ave.tif")
        one_year_tif_list=[]
        one_year_tif_list.append(tif_file)
        tif_file_year=tif_file[-18:-14]

  其中,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幅遙感影像。

  這裡相信大家也看到了為什麼我們要在前期先將文件夾中的文件按照“名稱”排序——是為了保證同一年成像的所有遙感影像都排列在一起,遍歷時只要遇到一個新的年份,程式就知道上一個年份的所有圖像都已經遍歷完畢了,就可以將上一個年份的所有柵格圖像加以平均值求取。

  本文代碼和前期博客中代碼不一樣的部分就在於,這裡是用到whitebox模塊而非arcpy模塊來實現同一年份遙感影像的逐像元平均值求取。在這裡,wbt.average_overlay()函數就是我們實現這一步驟的關鍵,其中inputs參數表示需要進行平均值計算的同一年份的所有遙感影像,output表示求取平均值後得到的結果圖像。

  最後,通過if tif_file==tif_file_name[len(tif_file_name)-1]:這個判斷,來確認是否目前已經遍歷到文件夾中的最後一個圖像文件。如果是的話,就需要將當前成像年份的所有圖像進行平均值的求取,並宣告代碼完成運行。

  這裡需要註意,由於我們在此沒有用到arcpy模塊,因此代碼也就不一定非要在 IDLE (Python GUI) 中運行了,常見的編譯器都可以運行。在代碼運行過程中,還可以看到具體運行情況與進度。

  代碼運行完畢後,即可得到求解平均值後的結果圖層。

  最後還有一個問題——在我用這一代碼進行實踐後發現,如果計算平均值前的圖層具有兩個或兩個以上的波段,那麼得到的結果圖層整體看還好,如下圖所示。

  但放大後,會發現得到的結果呈現出如下所示的條帶狀。

  而如果計算平均值前的圖層僅具有一個波段的話,就不會出現這種問題;如下圖所示。

  因此,大家在使用本文的代碼對大量長時間序列柵格遙感影像的每一個像元進行忽略Nodata值多時序平均值求取時,一定註意輸入圖層要僅含有一個波段;否則結果就會出現條帶狀的錯誤。


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

-Advertisement-
Play Games
更多相關文章
  • 元語言抽象就是建立新的語言。它在工程設計的所有分支中都扮演著重要的角色,在電腦程式設計領域更是特別重要。因為這個領域中,我們不僅可以設計新的語言,還可以通過構造求值器的方式實現這些語言。對某個程式設計語言的求值器(或者解釋器)也是一個過程,在應用於這個語言的一個表達式時,它能夠執行求值這個表達式所... ...
  • 本文將深入探討 AM 向 RM 申請並獲得 Container 資源後,在 NM 節點上如何啟動和清理 Container。將詳細分析整個過程的源碼實現。 ...
  • voidint/g g 是一個 Linux、macOS、Windows 下的命令行工具,可以提供一個便捷的多版本 go 環境的管理和切換。 在這裡我們介紹一下在 windows 下的使用,涉及到我們開發所需要用到的 幾個 go 項目層環境變數它們分別是 GOPATH,GOPROXY,GO111MOD ...
  • 在本文中,我們深入探討了 Spring 框架中 Bean 的實例化過程,關於某些細節以後我會單獨拿出一篇文章單獨講解,我們來總結下實例化都做了哪些事情:先從bean定義中載入當前類,因為最初Spring使用ASM技術解析元數據時只獲取了當前類的名稱尋找所有InstantiationAwareBean... ...
  • Python作為一門強大且靈活的編程語言,擁有豐富的數據類型系統。本文詳細介紹了Python中的每一種數據類型,包括數值、序列、映射、集合、布爾和None類型。每種數據類型的特性、使用方式,以及在實際問題中的應用都將被深入探討。此外,我們還將探討Python的動態類型特性,以及如何在實際編程中充分利... ...
  • Pytest - 概述&入門 簡介 Pytest是一款強大的python自動化測試工具,可以勝任各種類型或者級別的軟體測試工作; pytest提供了豐富的功能,包括assert重寫,第三方插件,以及其他測試工具無法比擬的fixture模型; pytest是一個軟體測試框架,是一款命令行工具,可以自動 ...
  • Elasticsearch是一個基於Lucene的搜索引擎。它提供了一個分散式多用戶能力的全文搜索引擎,基於RESTful 的API介面。Elasticsearch是用Java語言開發的,並作為Apache許可條款下的開放源碼發佈,是非常流行的企業級搜索引擎。 ...
  • 圖形驗證碼屬於老生常談了,具體細節這裡就不說了。生成圖形驗證碼的辦法非常多,今天講解一種通過Kaptcha組件快速生成圖形驗證碼的方法。Kaptcha是谷歌開源的一款簡單實用的圖形驗證碼組件。我個人推薦它的最大原因是容易上手,採用約定大於配置的方式,快速契合到項目中。話不多說,我們看看該如何使用它: ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...