Python实现snap:对齐多张遥感影像的空间范围.docx

Python实现snap:对齐多张遥感影像的空间范围.docx

  1. 1、本文档共2页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

Python实现snap:对齐多张遥感影像的空间范围

tif_file_path=rE:\02_Project\01_Chlorophyll\ClimateZone\Original

result_file_path=rE:\02_Project\01_Chlorophyll\ClimateZone\Original_Snap/

snap_file_name=rE:\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)

fortif_fileintif_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是裁剪后各个结果图像的保存路径(记得在这一路径后加一个正斜杠/,否则之后输出结果的路径会有问题),snap_file_name是裁剪其他栅格图像时,所用的模板栅格图像因为我们要统一各个栅格图像的行号与列号,所以很显然,这里这个模板图像就需要找各个栅格图像中,行数与列数均为最少的那一景图像。这里需要注意,如果大家的各个栅格图像中,行数与列数最少的栅格不是同一个栅格,那么可以分别用行数最少、列数最少的这两个栅格分别作为模板,执行两次上述代码。

代码整体思路也很简单:首先,我们基于arcpy.ListRasters()函数,获取tif_file_path路径下原有的全部.tif格式的图像文件,并以列表的形式存放于tif_file_list中;随后,逐一取出tif_file_list列表中的栅格文件,进行裁剪处理。这里的裁剪我们是通过arcpy.Clip_management()函数来实现的,其各项参数的具体含义大家可以参考官方帮助文档,我们这里就只对本文中需要修改的参数加以介绍。

其中,第一个参数就是当前循环所用的栅格图像文件,第三个参数是结果文件的保存路径与文件名,第四个参数则是模板文件;最后一个参数MAINTAIN_EXTENT是为了保证得到的裁剪后结果图像严格与模板图像的行数、列数相匹配。除此之外,几个#表示我们对其他参数暂时不配置。

此外,在代码开头的这句arcpy.env.snapRaster=snap_file_name,表明我们将以所选用的模板文件为标准,使得输出的结果文件的像元大小、图像范围等与模板文件保持一致。这里需要注意,这一句代码与前述的MAINTAIN_EXTENT参数缺一不可只有二者同时出现,才可以保证输出结果与模板文件是严格一致的。

另一方面,由于我们用到了ArcPy模块,因此如果大家的Python版本是3.0及以上,则需要在ArcMap软件中的Python运行框,或其对应的IDLE(如下图所示)中运行上述代码。

运行结果后,可以发现所有输出结果文件就具有完全一致的行数与列数了,且其各自的像元位置也是完全一致的。

至此,大功告成。

文档评论(0)

139****7676 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档