網(wǎng)站首頁 編程語言 正文
Python中ArcPy柵格裁剪柵格(批量對齊柵格圖像范圍并統(tǒng)一行數(shù)與列數(shù))_python
作者:瘋狂學(xué)習(xí)GIS ? 更新時(shí)間: 2023-06-16 編程語言??本文介紹基于Python中ArcPy
模塊,實(shí)現(xiàn)基于柵格圖像批量裁剪柵格圖像,同時(shí)對齊各個(gè)柵格圖像的空間范圍,統(tǒng)一其各自行數(shù)與列數(shù)的方法。
??首先明確一下我們的需求。現(xiàn)有某一地區(qū)的多張柵格遙感影像,其雖然都大致對應(yīng)著同樣的地物范圍,但不同柵格影像之間的空間范圍、行數(shù)與列數(shù)、像元的位置等都不完全一致;例如,某一景柵格影像會比其他柵格影像多出一行,而另一景柵格影像可能又會比其他柵格影像少一列等等。我們希望可以以其中某一景柵格影像為標(biāo)準(zhǔn),將全部的柵格影像的具體范圍、行數(shù)、列數(shù)等加以統(tǒng)一。
??本文所用到的具體代碼如下。
# -*- coding: utf-8 -*- """ Created on Thu Dec 29 21:13:19 2022 @author: fkxxgis """ import arcpy tif_file_path = r"E:\02_Project\01_Chlorophyll\ClimateZone\Original" result_file_path = r"E:\02_Project\01_Chlorophyll\ClimateZone\Original_Snap/" snap_file_name = r"E:\02_Project\01_Chlorophyll\ClimateZone\Original\F_LC.tif" arcpy.env.workspace = tif_file_path arcpy.env.snapRaster = snap_file_name tif_file_list = arcpy.ListRasters("*", "tif") for tif_file in tif_file_list: key_name = tif_file.split(".tif")[0] + "S.tif" arcpy.Clip_management(tif_file, "#", result_file_path + key_name, snap_file_name, "#", "#", "MAINTAIN_EXTENT")
??其中,tif_file_path
是保存有我們原有柵格圖像的路徑,result_file_path
是裁剪后各個(gè)結(jié)果圖像的保存路徑(記得在這一路徑后加一個(gè)正斜杠/
,否則之后輸出結(jié)果的路徑會有問題),snap_file_name
是裁剪其他柵格圖像時(shí),所用的模板柵格圖像——因?yàn)槲覀円y(tǒng)一各個(gè)柵格圖像的行號與列號,所以很顯然,這里這個(gè)模板圖像就需要找各個(gè)柵格圖像中,行數(shù)與列數(shù)均為最少的那一景圖像。這里需要注意,如果大家的各個(gè)柵格圖像中,行數(shù)與列數(shù)最少的柵格不是同一個(gè)柵格,那么可以分別用行數(shù)最少、列數(shù)最少的這兩個(gè)柵格分別作為模板,執(zhí)行兩次上述代碼。
??代碼整體思路也很簡單:首先,我們基于arcpy.ListRasters()
函數(shù),獲取tif_file_path
路徑下原有的全部.tif
格式的圖像文件,并以列表的形式存放于tif_file_list
中;隨后,逐一取出tif_file_list
列表中的柵格文件,進(jìn)行裁剪處理。這里的裁剪我們是通過arcpy.Clip_management()
函數(shù)來實(shí)現(xiàn)的,其各項(xiàng)參數(shù)的具體含義大家可以參考官方幫助文檔,我們這里就只對本文中需要修改的參數(shù)加以介紹。
??其中,第一個(gè)參數(shù)就是當(dāng)前循環(huán)所用的柵格圖像文件,第三個(gè)參數(shù)是結(jié)果文件的保存路徑與文件名,第四個(gè)參數(shù)則是模板文件;最后一個(gè)參數(shù)"MAINTAIN_EXTENT"
是為了保證得到的裁剪后結(jié)果圖像嚴(yán)格與模板圖像的行數(shù)、列數(shù)相匹配。除此之外,幾個(gè)"#"
表示我們對其他參數(shù)暫時(shí)不配置。
??此外,在代碼開頭的這句arcpy.env.snapRaster = snap_file_name
,表明我們將以所選用的模板文件為標(biāo)準(zhǔn),使得輸出的結(jié)果文件的像元大小、圖像范圍等與模板文件保持一致。這里需要注意,這一句代碼與前述的"MAINTAIN_EXTENT"
參數(shù)缺一不可——只有二者同時(shí)出現(xiàn),才可以保證輸出結(jié)果與模板文件是嚴(yán)格一致的。
??另一方面,由于我們用到了ArcPy模塊,因此如果大家的Python版本是3.0
及以上,則需要在ArcMap軟件中的Python運(yùn)行框,或其對應(yīng)的IDLE(如下圖所示)中運(yùn)行上述代碼。
??運(yùn)行結(jié)果后,可以發(fā)現(xiàn)所有輸出結(jié)果文件就具有完全一致的行數(shù)與列數(shù)了,且其各自的像元位置也是完全一致的。
原文鏈接:https://www.cnblogs.com/fkxxgis/p/17150814.html
- 上一篇:沒有了
- 下一篇:沒有了
相關(guān)推薦
- 2022-04-22 使用elementui,upload組件,既要上傳文件,又要提交表單
- 2022-03-14 1709 - Index column size too large. The maximum co
- 2022-05-19 yolov5返回坐標(biāo)的方法實(shí)例_python
- 2022-04-04 Python數(shù)據(jù)處理-導(dǎo)入導(dǎo)出excel數(shù)據(jù)_python
- 2022-10-14 VS Code注釋插件doxygen documentation generator
- 2022-04-14 Python實(shí)現(xiàn)注冊登錄功能_python
- 2022-02-16 瀏覽器斷點(diǎn)如何使用(測試工具)
- 2022-11-02 Python函數(shù)命名空間,作用域LEGB及Global詳析_python
- 欄目分類
-
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支