shp批量裁剪工具-基于Arcpy

本文介绍了如何利用Python的arcpy模块解决中文编码问题和裁剪栅格问题。作者在arcGIS 10.2环境下,通过da游标遍历面要素,使用Clip_analysis函数实现批量裁剪,并添加字段记录县域名称,最后合并所有裁剪结果。文章还分享了遇到的错误及解决方案。
摘要由CSDN通过智能技术生成

文章目录

前言

一、遇到的问题?

1.中文编码问题

2.arcpy函数问题

二、实现步骤

1.代码思路

2.制作脚本工具


前言

使用的arcpy为arcgis10.2对应版本。(python27)

想遍历面要素的多条记录实现批量裁剪功能,所幸找到用shp批量裁剪栅格的代码。在此基础上进行改进,记录一下实现过程和问题的解决。

https://www.likecs.com/show-203727205.html


一、遇到的问题?

1.中文编码问题

遇到如下报错

UnicodeEncodeError: 'ascii' codec can't encode characters in position

解决方法:设置编码

import sys
reload(sys)
sys.setdefaultencoding('utf-8')

2.arcpy函数问题

起初使用Clip_management裁剪,报错参数无效。于是找了很久的对应函数,最终在官网文档找到完美解答。ps:对应的函数位置和arcgis中工具箱位置是一致的。(arcpy.Clip_analysis同样可以实现shp裁剪shp)

裁剪函数如下:

arcpy.analysis.Clip(inputshp,row[0],resultPath+"\\"+tempShpName)

二、实现步骤

1.代码思路

与参考案例类似,首先通过游标遍历面数据子要素,在每次遍历过程中实现clip,并添加目标字段,这里添加的是县域名称,最后实现合并。

字段添加并赋值代码如下:

arcpy.AddField_management(Clip, "qu", "TEXT", "", "", 20)
result=arcpy.CalculateField_management(Clip, "qu", '\"'+ str(row[1]) + '\"',"VB", "")

 合并代码

合并的函数一定要找对应版本的官方文档,arcgis pro使用的是arcpy.ia.Merge,在这里也踩了坑。

arcpy.Merge_management(inFeatures, resultPath+"\\"+'water_merge'+'.shp')

2.制作脚本工具

自定义脚本工具实现流程不再赘述,csdn也有很多很好的教程。推荐GIS荟

 

全部代码如下:

import arcpy
import sys
reload(sys)
sys.setdefaultencoding('utf-8')

inputshp = arcpy.GetParameterAsText(0)
clipshp = arcpy.GetParameterAsText(1)
resultFolder = arcpy.GetParameterAsText(2)
inFeatures = []

# 实现批量clip
def clip(inputshp, clipshp, resultPath):
    #遍历面要素,SHAPE@为几何对象
    with arcpy.da.SearchCursor(clipshp, ["SHAPE@",'NAME']) as cursor:
        for row in cursor:
            tempShpName = str(row[1]) + '.shp'
            Clip=arcpy.analysis.Clip(inputshp,row[0],resultPath+"\\"+tempShpName)
            #添加字段
            arcpy.AddField_management(Clip, "qu", "TEXT", "", "", 20)
            #字段赋值
            result=arcpy.CalculateField_management(Clip, "qu", '\"'+ str(row[1]) + '\"',"VB", "")
            arcpy.AddMessage(row[1]+"success")
            inFeatures.append(result)
        #合并
        arcpy.Merge_management(inFeatures, resultPath+"\\"+'water_merge'+'.shp')
if __name__ == '__main__':
    clip(inputshp, clipshp, resultFolder)

实现效果如下:

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值