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("所有要素拆分完成。")
相关推荐
曲幽1 分钟前
你的FastAPI又在服务器上“跑不起来”了?来,今天咱把打包这件事彻底聊透
linux·windows·python·docker·fastapi·web·pyinstaller·nssm·services
AI玫瑰助手3 分钟前
Python函数:局部变量与全局变量的作用域
开发语言·python·信息可视化
imDwAaY4 分钟前
机器学习入门:从感知机到逻辑回归,理解线性分类器与Softmax CS188 Note20 学习笔记
人工智能·笔记·python·学习·机器学习·逻辑回归
2601_961194025 分钟前
2026初级会计实务教材电子版|章节讲义+习题PDF
python·考研·django·pdf·virtualenv·pygame
极客笔记Jack8 分钟前
Scanpy 富集分析实战:gseapy 从基因列表到通路解读
python
岁月宁静24 分钟前
Hermes Agent:让你的AI智能体越用越聪明
python·agent
财经资讯数据_灵砚智能32 分钟前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年5月29日
人工智能·python·信息可视化·自然语言处理·ai编程
触底反弹35 分钟前
从数据结构到 Prompt 设计:前端工程师的 AI 时代进阶指南
javascript·人工智能·python
好好风格36 分钟前
这个开源项目,把本地大模型做成会说话的 Live2D 桌宠
人工智能·python·开源
Ada's1 小时前
【计算机基础系列】python语言:环境搭建
开发语言·python