中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python中arcpy的示例分析

發布時間:2021-09-18 09:08:24 來源:億速云 閱讀:221 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關python中arcpy的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

需求

有多個文件地理數據庫(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_path2 = dataset_fc_path_lsit[i]
                #規則1:不能重疊
                arcpy.AddRuleToTopology_management(topology_path, "Must Not Overlap (Area)", fc_path2, "", "", "")
                for j in range(i + 1, len(dataset_fc_path_lsit)):
                    fc_path3 = dataset_fc_path_lsit[j]
                    # 規則2:不能重疊與其他要素類重疊
                    arcpy.AddRuleToTopology_management(topology_path, "Must Not Overlap With (Area-Area)", fc_path2, "", fc_path3, "")
            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的示例分析

感謝各位的閱讀!關于“python中arcpy的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

双桥区| 兴宁市| 天柱县| 青神县| 泗洪县| 获嘉县| 武穴市| 柏乡县| 佛山市| 吐鲁番市| 丹江口市| 巴东县| 沙坪坝区| 吕梁市| 鸡泽县| 囊谦县| 岑巩县| 中牟县| 台江县| 青田县| 论坛| 靖江市| 朝阳县| 延川县| 南丹县| 林甸县| 马尔康县| 裕民县| 元阳县| 泸溪县| 保定市| 南雄市| 兰考县| 太湖县| 资源县| 桃园市| 恭城| 葵青区| 武乡县| 甘肃省| 平谷区|