• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录

gisoracle

  • 博客园
  • 联系
  • 订阅
  • 管理

公告

View Post

ArcGIS Pro CAD转GIS

两年前,我创建过模型工具用来将CAD转为GIS,但是受限于一个模型只能使用一次迭代工具,我是做了多个子模型才完成转换的。原文如下。

ArcGIS Pro 模型构建器(1)——CAD转GIS_圈圈的圈圈的博客-CSDN博客_arcgis pro模型构建器最近拿到一个比较大的CAD测绘地形图,让帮忙转成GIS。尝试使用ArcGIS自带的工具——CAD至地理数据库、按属性分割,都不符合自己的需求。还是使用模型构建器构建一个模型吧。模型的示意图如下,因为涉及到两个迭代工具,所以做了一个主模型和一个子模型,另外设计一个Python截取字符串的脚本工具。主模型重命名模块2InterceptString(Python截取字符串脚本工具)impor...https://blog.csdn.net/baidu_28157641/article/details/105622239但是,我发现从Pro2.7之后,之前创建的模型工具运行出现了问题,迭代器的功能又被削了(如果主模型和子模型都有迭代要素类工具,那主模型的迭代器只能迭代一次)。。。所以考虑不依赖模型工具而是创建脚本工具,在一个脚本中就能够完成CAD至GIS的转换工作。尝试很久之后终于实现了,效果与原文相同。

Python脚本

    import os
    import arcpy
     
    # 必填参数:需要装换的CAD文件路径
    cad = arcpy.GetParameterAsText(0)
     
     
    # 获取带后缀名称
    cad_fullname = os.path.basename(cad)
     
    # 获取文件路径
    cad_path = os.path.dirname(cad)
     
    # 获取文件名
    cad_name = os.path.splitext(cad_fullname)[0]
     
     
    # 工作空间设置为cad所在的文件夹
    arcpy.env.workspace = cad_path
    # 创建与cad同名同路径的gdb
    if arcpy.Exists(cad_name+".gdb"):
        arcpy.Delete_management(cad_name+".gdb")
        gdb = arcpy.management.CreateFileGDB(cad_path, cad_name+".gdb", "CURRENT")
    else:
        gdb = arcpy.management.CreateFileGDB(cad_path, cad_name+".gdb", "CURRENT")
    arcpy.AddMessage("已创建:"+cad_name+".gdb")
     
    # 可选参数:坐标系
    sr = arcpy.GetParameterAsText(1)
    # 循环CAD数据集
    cad_datasets = arcpy.ListFeatureClasses(feature_dataset=cad_fullname)
    for cad_dataset in cad_datasets:
        arcpy.AddMessage("开始转换:"+cad_fullname+"\\"+cad_dataset)
        gdb_dataset = arcpy.management.CreateFeatureDataset(gdb, cad_dataset, sr)
        # 写入gdb要素数据集
        arcpy.analysis.SplitByAttributes(
            cad+"\\"+cad_dataset, gdb_dataset, "Layer")
        # 重命名
        fcs = arcpy.ListFeatureClasses(
            feature_dataset=cad_name+".gdb\\"+cad_dataset)
        for fc in fcs:
            arcpy.management.Rename(
                cad_name+".gdb\\"+cad_dataset+"\\"+fc, fc+"_"+cad_dataset)

脚本运行演示
1e3b9ae12cf14cf59719191d87f770a8.gif

注:转换后的gdb数据库与CAD文件在一起

 
————————————————
版权声明:本文为CSDN博主「学学GIS」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/baidu_28157641/article/details/124577377

posted on 2023-02-08 15:25  gisai  阅读(165)  评论(0)    收藏  举报

刷新页面返回顶部
 
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3