python arcpy练习之面要素重叠拓扑检查

作者:Ah·Week 时间:2021-12-24 12:41:42 

需求

有多个文件地理数据库(gdb),数据库内有多个面要素类图层,每个图层不能有自重叠,也不能和其他图层重叠。所以,需要为每个文件地理数据库(gdb)进行拓扑检查。

思路

1.在输出文件夹下新建与输入文件夹下同名的gdb。

2.在gdb内新建要素类数据集。

3.在数据集内创建拓扑。

4.向拓扑中添加要素类。

5.添加拓扑规则。

6.拓扑验证。

7.导出拓扑错误。

python arcpy练习之面要素重叠拓扑检查

将需要拓扑的gdb放入同一个文件夹下,用python代码串连起来利用循环遍历gdb便可以进行批量拓扑了。

代码


# -*- coding: gbk -*-
import os
import arcpy
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
arcpy.AddMessage(sys.getdefaultencoding())
arcpy.env.XYResolution = "0.0001 Meters" #设置XY分辨率
arcpy.env.XYTolerance = "0.001 Meters"   #设置XY容差
def checkTopology(in_path, out_path):
   cout = 0
   fail = 0
   warning = 0
   fail_list = []
   warning_list = []
   arcpy.env.workspace = in_path
   workspaces = arcpy.ListWorkspaces("*", "ALL")
   for workspace in workspaces:
       arcpy.AddMessage("=" * 60)
       cout += 1
       arcpy.AddMessage(" (" + str(cout) + ") " + os.path.basename(workspace))
       arcpy.AddMessage("  ")
       try:
           # 将每个gdb设为工作区
           arcpy.env.workspace = workspace
           fc_list = arcpy.ListFeatureClasses() #列出gdb内的要素类图层
           in_fc_path_list = []
           for fc in fc_list:
               in_fc_path_list.append(os.path.join(workspace,fc))
           # 在输出路径out_path下新建gdb
           gdb_name1 = os.path.basename(workspace)
           result_gdb = os.path.join(out_path, gdb_name1)
           if not arcpy.Exists(result_gdb):
               arcpy.AddMessage("    新建 " + result_gdb + " ...")
               arcpy.CreateFileGDB_management(out_path, gdb_name1)
           else:
               arcpy.AddWarning(result_gdb + " 已存在!")
               warning_list.append(result_gdb)
               warning += 1
               continue
           arcpy.AddMessage("    在 " + result_gdb + " 内新建要素数据集...")
           dataset_name = "dataset"
           dataset_path = os.path.join(result_gdb,dataset_name)
           # 引用包含要应用的空间参考的要素类或要素数据集,
           # 将in_fc_path_list[0]的坐标作为要素数据集的坐标,所以gdb内的所有要素类应该是统一坐标
           arcpy.CreateFeatureDataset_management(result_gdb, dataset_name, in_fc_path_list[0])
           #导入要素类到数据集
           arcpy.AddMessage("    向 " + dataset_path + " 导入要素类图层...")
           arcpy.FeatureClassToGeodatabase_conversion(in_fc_path_list,dataset_path)
           #在dataset数据内创建拓扑
           arcpy.AddMessage("    创建拓扑...")
           topology_name = "topology"
           topology_path = os.path.join(dataset_path, topology_name)
           arcpy.CreateTopology_management(dataset_path, topology_name)
           # 将导入dataset的要素类添加到拓扑中
           arcpy.AddMessage("    向拓扑中添加要素类...")
           dataset_fc_path_lsit = []  #数据集中的要素类绝对路径列表
           for ifc_name in fc_list:
               # 拼接数据集中的要素类绝对路径
               dataset_fc_path = os.path.join(dataset_path,ifc_name)
               dataset_fc_path_lsit.append(dataset_fc_path)
               arcpy.AddFeatureClassToTopology_management(topology_path, dataset_fc_path, "1", "1")
           arcpy.AddMessage("    添加拓扑规则...")
           for i in range(len(dataset_fc_path_lsit)):
               fc_path1 = dataset_fc_path_lsit[i]
               #规则1:不能重叠
               arcpy.AddRuleToTopology_management(topology_path, "Must Not Overlap (Area)", fc_path1, "", "", "")
               for j in range(i + 1, len(dataset_fc_path_lsit)):
                   fc_path2 = dataset_fc_path_lsit[j]
                   # 规则2:不能重叠与其他要素类重叠
                   arcpy.AddRuleToTopology_management(topology_path, "Must Not Overlap With (Area-Area)", fc_path1, "", fc_path2, "")
           arcpy.AddMessage("    拓扑验证...")
           arcpy.ValidateTopology_management(topology_path, "Full_Extent")
           arcpy.AddMessage("    导出拓扑错误...")
           arcpy.ExportTopologyErrors_management(topology_path, dataset_path, "topoError")
       except Exception as e:
           arcpy.AddError(e.message)
           arcpy.AddError("    " + os.path.basename(workspace) + " 失败!")
           fail_list.append(os.path.basename(workspace))
           fail += 1
   arcpy.AddMessage('+' * 60)
   arcpy.AddMessage(u"  成功:" + str(cout - fail - warning) + u" 个!")
   if warning > 0:
       arcpy.AddWarning(u"  警告:" + str(warning) + u" 个! 如下:")
       arcpy.AddWarning("####" + '*' * 20)
       for fff in warning_list:
           arcpy.AddWarning("  " + fff)
       arcpy.AddWarning("####" + '*' * 20)
   if fail > 0:
       arcpy.AddError(u"  失败:" + str(fail) + u" 个! 如下:")
       arcpy.AddError("####" + '*' * 20)
       for ff in fail_list:
           arcpy.AddError("  " + ff)
       arcpy.AddError("####" + '*' * 20)
   arcpy.AddMessage('+' * 60)
if __name__ == "__main__":
   in_path_globle = arcpy.GetParameterAsText(0)
   out_path_globe = arcpy.GetParameterAsText(1)
   checkTopology(in_path_globle,out_path_globe)

效果图

python arcpy练习之面要素重叠拓扑检查

python arcpy练习之面要素重叠拓扑检查

python arcpy练习之面要素重叠拓扑检查

来源:https://blog.csdn.net/qz_CSDN/article/details/120330887

标签:python,arcpy,练习
0
投稿

猜你喜欢

  • python return实现汇率转换器教程示例

    2023-11-10 12:39:50
  • 小议sqlserver数据库主键选取策略

    2011-10-24 19:51:30
  • python性能测试手机号验证码登录压测示例详解

    2021-06-05 13:21:25
  • 5个常见的XHTML验证错误

    2010-01-15 20:24:00
  • Mootools常用方法扩展(五)

    2009-03-03 12:12:00
  • asp的access数据库备份 压缩 恢复及清理数据库函数

    2008-10-31 12:36:00
  • IE中jscript/javascript的条件编译

    2007-10-03 14:03:00
  • python的简单web框架flask快速实现详解

    2023-03-10 08:26:36
  • 详解Python如何巧妙实现数学阶乘n!

    2023-07-06 10:22:56
  • 提高CSS代码的可读性

    2008-05-11 18:59:00
  • MySQL分区的功能和限制讲解

    2010-10-14 14:03:00
  • Python 添加命令行参数步骤

    2022-10-24 05:15:40
  • python+requests+unittest API接口测试实例(详解)

    2021-10-14 13:15:08
  • PL/SQL实现Oracle数据库任务调度

    2010-07-20 12:57:00
  • python中subprocess实例用法及知识点详解

    2022-12-03 00:27:39
  • 在Dreamweaver MX中应用“占位图形”

    2009-07-10 13:16:00
  • Python 做曲线拟合和求积分的方法

    2021-03-03 01:46:07
  • python实现从ftp服务器下载文件的方法

    2023-08-02 20:50:54
  • PHP实现数组根据某个字段进行水平合并,横向合并案例分析

    2023-10-04 04:55:53
  • [翻译]标记语言和样式手册 Chapter 4 引用

    2008-01-20 14:19:00
  • asp之家 网络编程 m.aspxhome.com