欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python arcpy練習(xí)之面要素重疊拓?fù)錂z查

 更新時(shí)間:2021年09月17日 16:53:52   作者:Ah·Week  
今天小編就為大家分享一篇Python ArcPy的面要素重疊拓?fù)錂z查,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

需求

有多個(gè)文件地理數(shù)據(jù)庫(kù)(gdb),數(shù)據(jù)庫(kù)內(nèi)有多個(gè)面要素類圖層,每個(gè)圖層不能有自重疊,也不能和其他圖層重疊。所以,需要為每個(gè)文件地理數(shù)據(jù)庫(kù)(gdb)進(jìn)行拓?fù)錂z查。

思路

1.在輸出文件夾下新建與輸入文件夾下同名的gdb。

2.在gdb內(nèi)新建要素類數(shù)據(jù)集。

3.在數(shù)據(jù)集內(nèi)創(chuàng)建拓?fù)洹?/p>

4.向拓?fù)渲刑砑右仡悺?/p>

5.添加拓?fù)湟?guī)則。

6.拓?fù)潋?yàn)證。

7.導(dǎo)出拓?fù)溴e(cuò)誤。

將需要拓?fù)涞膅db放入同一個(gè)文件夾下,用python代碼串連起來利用循環(huán)遍歷gdb便可以進(jìn)行批量拓?fù)淞恕?/p>

代碼

# -*- coding: gbk -*-
import os
import arcpy
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
arcpy.AddMessage(sys.getdefaultencoding())
arcpy.env.XYResolution = "0.0001 Meters" #設(shè)置XY分辨率
arcpy.env.XYTolerance = "0.001 Meters"   #設(shè)置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:
            # 將每個(gè)gdb設(shè)為工作區(qū)
            arcpy.env.workspace = workspace
            fc_list = arcpy.ListFeatureClasses() #列出gdb內(nèi)的要素類圖層
            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 + " 內(nèi)新建要素?cái)?shù)據(jù)集...")
            dataset_name = "dataset"
            dataset_path = os.path.join(result_gdb,dataset_name)
            # 引用包含要應(yīng)用的空間參考的要素類或要素?cái)?shù)據(jù)集,
            # 將in_fc_path_list[0]的坐標(biāo)作為要素?cái)?shù)據(jù)集的坐標(biāo),所以gdb內(nèi)的所有要素類應(yīng)該是統(tǒng)一坐標(biāo)
            arcpy.CreateFeatureDataset_management(result_gdb, dataset_name, in_fc_path_list[0])
            #導(dǎo)入要素類到數(shù)據(jù)集
            arcpy.AddMessage("    向 " + dataset_path + " 導(dǎo)入要素類圖層...")
            arcpy.FeatureClassToGeodatabase_conversion(in_fc_path_list,dataset_path)
            #在dataset數(shù)據(jù)內(nèi)創(chuàng)建拓?fù)?
            arcpy.AddMessage("    創(chuàng)建拓?fù)?..")
            topology_name = "topology"
            topology_path = os.path.join(dataset_path, topology_name)
            arcpy.CreateTopology_management(dataset_path, topology_name)
            # 將導(dǎo)入dataset的要素類添加到拓?fù)渲?
            arcpy.AddMessage("    向拓?fù)渲刑砑右仡?..")
            dataset_fc_path_lsit = []  #數(shù)據(jù)集中的要素類絕對(duì)路徑列表
            for ifc_name in fc_list:
                # 拼接數(shù)據(jù)集中的要素類絕對(duì)路徑
                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("    添加拓?fù)湟?guī)則...")
            for i in range(len(dataset_fc_path_lsit)):
                fc_path1 = dataset_fc_path_lsit[i]
                #規(guī)則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]
                    # 規(guī)則2:不能重疊與其他要素類重疊
                    arcpy.AddRuleToTopology_management(topology_path, "Must Not Overlap With (Area-Area)", fc_path1, "", fc_path2, "")
            arcpy.AddMessage("    拓?fù)潋?yàn)證...")
            arcpy.ValidateTopology_management(topology_path, "Full_Extent")
            arcpy.AddMessage("    導(dǎo)出拓?fù)溴e(cuò)誤...")
            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" 個(gè)!")
    if warning > 0:
        arcpy.AddWarning(u"  警告:" + str(warning) + u" 個(gè)! 如下:")
        arcpy.AddWarning("####" + '*' * 20)
        for fff in warning_list:
            arcpy.AddWarning("  " + fff)
        arcpy.AddWarning("####" + '*' * 20)
    if fail > 0:
        arcpy.AddError(u"  失敗:" + str(fail) + u" 個(gè)! 如下:")
        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)

效果圖

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • Python文件夾與文件的操作實(shí)現(xiàn)代碼

    Python文件夾與文件的操作實(shí)現(xiàn)代碼

    最近在寫的程序頻繁地與文件操作打交道,這塊比較弱,還好在百度上找到一篇不錯(cuò)的文章,這是原文傳送門,我對(duì)原文稍做了些改動(dòng)
    2014-07-07
  • 手把手教你python實(shí)現(xiàn)SVM算法

    手把手教你python實(shí)現(xiàn)SVM算法

    這篇文章主要為大家詳細(xì)介紹了手把手教你python實(shí)現(xiàn)SVM算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-12-12
  • python使用Plotly繪圖工具繪制水平條形圖

    python使用Plotly繪圖工具繪制水平條形圖

    這篇文章主要為大家詳細(xì)介紹了python使用Plotly繪圖工具繪制水平條形圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • python實(shí)現(xiàn)關(guān)鍵詞提取的示例講解

    python實(shí)現(xiàn)關(guān)鍵詞提取的示例講解

    下面小編就為大家分享一篇python實(shí)現(xiàn)關(guān)鍵詞提取的示例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • pandas中merge()函數(shù)的用法解讀

    pandas中merge()函數(shù)的用法解讀

    這篇文章主要介紹了pandas中merge()函數(shù)的用法解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Python基礎(chǔ)詳解之列表復(fù)制

    Python基礎(chǔ)詳解之列表復(fù)制

    這篇文章主要介紹了Python基礎(chǔ)詳解之列表復(fù)制,文中有非常詳細(xì)的代碼示例,對(duì)正在學(xué)習(xí)python基礎(chǔ)的小伙伴們有很好的幫助,需要的朋友可以參考下
    2021-04-04
  • 基于Python+tkinter實(shí)現(xiàn)簡(jiǎn)易計(jì)算器桌面軟件

    基于Python+tkinter實(shí)現(xiàn)簡(jiǎn)易計(jì)算器桌面軟件

    tkinter是Python的標(biāo)準(zhǔn)GUI庫(kù),對(duì)于初學(xué)者來說,它非常友好,因?yàn)樗峁┝舜罅康念A(yù)制部件,本文小編就來帶大家詳細(xì)一下如何利用tkinter制作一個(gè)簡(jiǎn)易計(jì)算器吧
    2023-09-09
  • Pygame游戲開發(fā)之太空射擊實(shí)戰(zhàn)入門篇

    Pygame游戲開發(fā)之太空射擊實(shí)戰(zhàn)入門篇

    相信大多數(shù)8090后都玩過太空射擊游戲,在過去游戲不多的年代太空射擊自然屬于經(jīng)典好玩的一款了,今天我們來自己動(dòng)手實(shí)現(xiàn)它,在編寫學(xué)習(xí)中回顧過往展望未來,下面開始入門篇
    2022-08-08
  • PyQT5 QTDesigner窗口及組成的實(shí)現(xiàn)

    PyQT5 QTDesigner窗口及組成的實(shí)現(xiàn)

    這篇文章主要介紹了PyQT5 QTDesigner窗口及組成的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Python自動(dòng)化測(cè)試框架之unittest使用詳解

    Python自動(dòng)化測(cè)試框架之unittest使用詳解

    unittest是Python自動(dòng)化測(cè)試框架之一,提供了一系列測(cè)試工具和接口,支持單元測(cè)試、功能測(cè)試、集成測(cè)試等多種測(cè)試類型。unittest使用面向?qū)ο蟮乃枷雽?shí)現(xiàn)測(cè)試用例的編寫和管理,可以方便地?cái)U(kuò)展和定制測(cè)試框架,支持多種測(cè)試結(jié)果輸出格式
    2023-04-04

最新評(píng)論