当前位置:   article > 正文

ArcGIS Python使用及批量裁剪示例_extractbymask

extractbymask

ArcGIS中的工具均提供Python函数,方便支持批量处理。以掩膜裁剪(提取分析/Extract by Mask)为例,

可以查找到帮助文档“按掩膜提取”(源1)(源2),路径“工具参考/工具/Spatial Analyst 工具箱/按掩膜提取”函数为:Extract by Mask

Extract by Mask的基本语法是:

ExtractByMask (in_raster, in_mask_data)

in_raster:提取像元的输入栅格。

in_mask_data:用于定义提取区域的输入掩膜数据。它可以是栅格,也可以是要素数据集。

代码示例

以下以批量读取裁剪某文件夹下的tif数据为例(特别注意Python2脚本循环语句格式的空格不能用Tab,否则会报错Indent;

另外在使用不同的矢量裁剪同一影像时,为保证裁剪后范围一致需设置范围为输入栅格范围。例如下面的:

rd = arcpy.sa.Raster(inRaster)
# Set the extent environment as the raster, very important for clip with different vector
arcpy.env.extent = rd.extent
):

  1. # Import system modules
  2. import arcpy
  3. from arcpy import env
  4. from arcpy.sa import *
  5. # Set environment settings
  6. env.workspace = "D:/img"
  7. rasterList = arcpy.ListRasters("*","tif")
  8. #输出路径
  9. output_path = "D:/imgMask/"
  10. # mask shp
  11. inMaskData = "D:/range.shp"
  12. for raster in rasterList:
  13. print raster
  14. # Set local variables
  15. inRaster = raster
  16. rd = arcpy.sa.Raster(inRaster)
  17. # Set the extent environment as the raster, very important for clip with different vector
  18. arcpy.env.extent = rd.extent
  19. # Execute ExtractByMask
  20. outExtractByMask = ExtractByMask(inRaster, inMaskData)
  21. # Save the output
  22. out = output_path + inRaster #对生成文件进行命名
  23. outExtractByMask.save(out)

代码执行

方式一:将代码保存为单独的py文件,cmd或其它IDE执行。cmd执行命令(如何独立运行脚本):

C:\Python27\ArcGIS10.3\python.exe my_script.py

方式二:ArcGIS安装的Python IDE里执行

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/310597
推荐阅读
相关标签
  

闽ICP备14008679号