Python實(shí)現(xiàn)批量填補(bǔ)遙感影像的無效值NoData
本文介紹基于Python中ArcPy模塊,對(duì)大量柵格遙感影像文件批量進(jìn)行無效值(NoData值)填充的方法。
在處理柵格圖像文件時(shí),我們經(jīng)常會(huì)遇到圖像中存在有無效值(即NoData值)的情況。如下圖所示,這里有一個(gè)矢量面要素圖層和該矢量圖層范圍對(duì)應(yīng)的一景柵格圖像;可以看到,由于該柵格圖像存在無效值NoData,因此柵格圖像是沒有完全遮蓋矢量圖層的。
在一些情況下,這些無效值可能會(huì)對(duì)我們的后續(xù)圖像處理操作帶來很多麻煩。那么,我們可以通過代碼,對(duì)大量存在NoData值的柵格圖像進(jìn)行無效值填充。
首先,我們來明確一下本文的具體需求?,F(xiàn)有一個(gè)存儲(chǔ)有多張.tif
格式遙感影像的文件夾,且文件夾內(nèi)除了.tif
格式的遙感影像文件外,還具有其它格式的文件。
其中,每一個(gè).tif
格式遙感影像都存在若干無效值像元;我們希望對(duì)每一張遙感影像進(jìn)行NoData值的填充。
明確了需求后,我們就可以開始具體的操作。首先,本文所需用到的代碼如下。
# -*- coding: utf-8 -*- """ Created on Tue Apr 19 14:53:49 2022 @author: fkxxgis """ import arcpy from arcpy.sa import * tif_file_path="E:/LST/Data/MODIS/13_Average/" fill_file_path="E:/LST/Data/MODIS/14_AverageFill/" arcpy.env.workspace=tif_file_path tif_file_name=arcpy.ListRasters("*","tif") for tif_file in tif_file_name: fill_file=arcpy.sa.Con(IsNull(tif_file), FocalStatistics(tif_file,NbrAnnulus(1,12,"CELL"),"MEAN"), tif_file) fill_result_path=fill_file_path+tif_file.strip(".tif")+"_Fill.tif" fill_file.save(fill_result_path)
其中,tif_file_path
是原有填充無效值前遙感圖像的保存路徑,fill_file_path
是我們新生成的填充無效值后遙感影像的保存路徑,也就是結(jié)果保存路徑。
首先,我們利用arcpy.ListRasters()
函數(shù),獲取路徑下原有的全部.tif
格式的圖像文件;接下來,遍歷tif_file_path
路徑下全部.tif
格式圖像文件,并分別執(zhí)行arcpy.sa.Con()
這個(gè)柵格計(jì)算函數(shù)。其中,該函數(shù)中IsNull(tif_file)
表示首先選擇每一景圖像中的無效值像元,隨后通過FocalStatistics()
函數(shù)進(jìn)行無效值的填充;NbrAnnulus(1,12,"CELL")
參數(shù)表示,以當(dāng)前無效值像元為圓心,12
為圓環(huán)外半徑,1
為圓環(huán)內(nèi)半徑,構(gòu)建一個(gè)圓環(huán)作為參考區(qū)域,從而以圓環(huán)內(nèi)所有像元的值作為參考進(jìn)行圓心處該無效值像元的填充(除了圓環(huán),還可以設(shè)置矩形、扇形、圓形等);"MEAN"
參數(shù)表示以剛剛這個(gè)圓環(huán)中全部像元數(shù)值的平均值作為圓心處該無效值像元的數(shù)值。最后,我們?cè)谠羞b感影像文件名后添加"_Fill.tif"
后綴,作為填充后遙感影像文件的新文件名。
在 IDLE (Python GUI) 中運(yùn)行代碼。代碼運(yùn)行完畢后,我們選取一景圖像,對(duì)比填充前后的圖像結(jié)果,如下圖所示;其中,這一張是填充前圖像。
這一張則為填充后圖像。
通過對(duì)比,我們可以看到填充后圖像中的空白區(qū)域(NoData值區(qū)域)已經(jīng)明顯較之填充前圖像有了很大程度的減少(圖像右下角尤為明顯)。如果大家想讓更多的NoData值區(qū)域得到填充,就可以將FocalStatistics()
函數(shù)中設(shè)定的參考區(qū)域的范圍更大一些;當(dāng)然,這樣也會(huì)稍微降低填充值的精度,大家結(jié)合實(shí)際需要來操作即可。
到此這篇關(guān)于Python實(shí)現(xiàn)批量填補(bǔ)遙感影像的無效值NoData的文章就介紹到這了,更多相關(guān)Python填補(bǔ)遙感影像無效值內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Python?ArcPy實(shí)現(xiàn)批量對(duì)大量遙感影像相減做差
- Python?ArcPy實(shí)現(xiàn)批量計(jì)算多時(shí)相遙感影像的各項(xiàng)元平均值
- Python?ArcPy批量掩膜、重采樣大量遙感影像的操作
- Python實(shí)現(xiàn)批量繪制遙感影像數(shù)據(jù)的直方圖
- Python高光譜遙感影像處理問題詳細(xì)分析講解
- 詳解Python修復(fù)遙感影像條帶的兩種方式
- Python 實(shí)現(xiàn)遙感影像波段組合的示例代碼
- 利用python GDAL庫讀寫geotiff格式的遙感影像方法
- Python中使用OpenCV庫來進(jìn)行簡(jiǎn)單的氣象學(xué)遙感影像計(jì)算
- 基于Python批量鑲嵌拼接遙感影像/柵格數(shù)據(jù)(示例代碼)
相關(guān)文章
python 3利用Dlib 19.7實(shí)現(xiàn)攝像頭人臉檢測(cè)特征點(diǎn)標(biāo)定
這篇文章主要為大家詳細(xì)介紹了python 3利用Dlib 19.7實(shí)現(xiàn)攝像頭人臉檢測(cè)特征點(diǎn)標(biāo)定,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02Python的Pandas庫中使用DataFrame篩選和刪除含特定值的行與列
Pandas是一個(gè)強(qiáng)大的數(shù)據(jù)處理庫,提供了各種功能來操作和處理數(shù)據(jù),這篇文章主要給大家介紹了關(guān)于Python的Pandas庫中使用DataFrame篩選和刪除含特定值的行與列的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05python pip安裝的包放在哪個(gè)目錄(site-packages目錄的位置)
這篇文章主要介紹了python pip安裝的包放在哪個(gè)目錄(site-packages目錄的位置),通常安裝在python安裝目錄下的lib/site-packages目錄下,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-066行Python代碼實(shí)現(xiàn)進(jìn)度條效果(Progress、tqdm、alive-progress
這篇文章主要介紹了6行Python代碼實(shí)現(xiàn)進(jìn)度條效果(Progress、tqdm、alive-progress和PySimpleGUI庫),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01解決import tensorflow導(dǎo)致jupyter內(nèi)核死亡的問題
這篇文章主要介紹了解決import tensorflow導(dǎo)致jupyter內(nèi)核死亡的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02詳解基于Transformer實(shí)現(xiàn)電影評(píng)論星級(jí)分類任務(wù)
這篇文章主要為大家介紹了詳解基于Transformer實(shí)現(xiàn)電影評(píng)論星級(jí)分類任務(wù)過程解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04