Arcpy Python拆分shp数据要素为多个shp

我有一个各县shp文件,我想要拆分成不同的要素,命名根据NAME字段进行命名,字段值是字符串,以下为基于arcpy的python实现代码。(python2.7)

python 复制代码
import arcpy
import os

# 设置工作空间和输入的 shapefile 文件路径
arcpy.env.workspace = r"E:\geo\county"
input_shp = r"E:\geo\县.shp"

# 检查 NAME 字段是否存在
field_list = arcpy.ListFields(input_shp)
field_names = [field.name for field in field_list]
if "NAME" not in field_names:
    print("NAME 字段不存在于输入的 shapefile 中。")
    arcpy.Quit()

# 使用 SearchCursor 遍历每个要素,并根据 NAME 字段进行拆分
with arcpy.da.SearchCursor(input_shp, ["NAME", "SHAPE@"]) as cursor:
    for row in cursor:
        name_value = row[0]  # 获取 NAME 字段的值
        feature_geom = row[1]  # 获取要素的几何对象

        # 创建新的 shapefile 名称,并确保合法性
        output_name = arcpy.ValidateTableName(name_value)  # 使用 ValidateTableName 确保合法的名称
        output_shp = os.path.join(arcpy.env.workspace, output_name + ".shp")

        # 如果同名文件已经存在,则添加数字以避免冲突
        if arcpy.Exists(output_shp):
            counter = 1
            while arcpy.Exists(output_shp):
                counter += 1
                output_shp = os.path.join(arcpy.env.workspace, output_name + "_" + str(counter) + ".shp")

        # 使用 FeatureClassToFeatureClass_conversion 方法将单个要素导出为新的 shapefile
        where_clause = u'"NAME"=\'{}\''.format(name_value)  # 使用 unicode 字符串处理非ASCII字符
        arcpy.FeatureClassToFeatureClass_conversion(in_features=input_shp,
                                                    out_path=arcpy.env.workspace,
                                                    out_name=output_name,
                                                    where_clause=where_clause,
                                                    field_mapping=None,
                                                    config_keyword=None)

        # 设置导出的 shapefile 的空间参考
        arcpy.DefineProjection_management(output_shp, feature_geom.spatialReference)

        # 打印已导出的要素名称和路径
        print(u"已导出要素 {} 到 {}".format(name_value, output_shp))

print("所有要素拆分完成。")
相关推荐
pr_note34 分钟前
python|if判断语法对比
python
apocelipes3 小时前
golang unique包和字符串内部化
java·python·性能优化·golang
Geoking.4 小时前
NumPy zeros() 函数详解
python·numpy
Full Stack Developme4 小时前
java.text 包详解
java·开发语言·python
丁浩6665 小时前
Python机器学习---2.算法:逻辑回归
python·算法·机器学习
B站_计算机毕业设计之家5 小时前
计算机毕业设计:Python农业数据可视化分析系统 气象数据 农业生产 粮食数据 播种数据 爬虫 Django框架 天气数据 降水量(源码+文档)✅
大数据·爬虫·python·机器学习·信息可视化·课程设计·农业
Q_Q5110082855 小时前
python+uniapp基于微信小程序的旅游信息系统
spring boot·python·微信小程序·django·flask·uni-app·node.js
鄃鳕5 小时前
python迭代器解包【python】
开发语言·python
懷淰メ6 小时前
python3GUI--模仿百度网盘的本地文件管理器 By:PyQt5(详细分享)
开发语言·python·pyqt·文件管理·百度云·百度网盘·ui设计
Q_Q5110082856 小时前
python基于web的汽车班车车票管理系统/火车票预订系统/高铁预定系统 可在线选座
spring boot·python·django·flask·node.js·汽车·php