利用shp文件批量裁剪tif文件的python代码

import arcpy

"""
基于矢量文件(shp)对tif进行裁剪
2024.01.12, 22:18, YMJ
"""

# 定义shp裁剪tif的函数
def clip_tiff_with_shapefile_mask(tiff_file, shapefile, output_file):
    arcpy.env.workspace = "D:\\YRB"

    arcpy.env.outputCoordinateSystem = arcpy.Describe(shapefile).spatialReference
    arcpy.env.outputMFlag = "Disabled"
    arcpy.env.outputZFlag = "Disabled"
    arcpy.env.outputCoordinateSystem = arcpy.Describe(shapefile).spatialReference

    # arcpy.Clip_management(tiff_file, "#", output_file, shapefile, "0", "ClippingGeometry", "NO_MAINTAIN_EXTENT")
    arcpy.Clip_management(tiff_file,"#", output_file, shapefile,"NoData","ClippingGeometry","NO_MAINTAIN_EXTENT")

# 存储大量被用于裁剪的tif文件的路径
dir = "D:\\CMFD\\Month\\1"
# 裁剪的shp文件
shp_file = "D:\\CMFD\\test\\area.shp"

# 遍历路径,将每个tif文件的绝对路径存储到列表中
file_list = []
for root,subroot,files in os.walk(dir):
    for file in files:
        if file.endswith(".tif"):
            file_path = os.path.join(root, file)
            file_list.append(file_path)
# print(file_list)

# 遍历存储了tif文件绝对路径的列表
for i in range(len(file_list)):
    print(file_list[i])

    # 构建输出路径
    output_file = "D:\\YRB\\SGCF\\" + file_list[i].split("\\")[4] + "\\" + \
                    file_list[i].split("\\")[4] + "_" + file_list[i].split("_")[-1]

    # 调用函数
    clip_tiff_with_shapefile_mask(file_list[i], shp_file, output_file)

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值