• 【arcpy】创建点、线、面(孔洞、环、多部件)要素、要素类


    创建点要素、要素类

    复制代码
    #coding=utf-8
    import arcpy
    
    # 点并非几何类,但通常用于构造几何。PointGeometry是几何。
    point=arcpy.Point(10,10)
    point_Geometry=arcpy.PointGeometry(point)
    
    # 调用创建要素类工具创建一个 点要素类
    point_featureClass=arcpy.CreateFeatureclass_management(r'E:3 codingpy codearcpycreatepoint','point.shp','POINT')
    
    # 使用arcpy.da.InsertCursor类插入新创建的 点要素 到 点要素类
    insertCursor = arcpy.da.InsertCursor(point_featureClass, ['Shape@'])
    insertCursor.insertRow([point_Geometry])
    
    del insertCursor
    复制代码

    创建线要素、要素类

    复制代码
    #coding=utf-8
    import arcpy
    
    points=[[0,0],[0,10],[10,10],[10,0]]
    
    # 组成Path的Array对象
    path=arcpy.Array([arcpy.Point(*p) for p in points])
    
    # 通过path(Array)创建Polyline对象
    line_Geometry=arcpy.Polyline(path)
    
    # 调用创建要素类工具创建一个 线要素类
    polyline_featureClass=arcpy.CreateFeatureclass_management(r'E:3 codingpy codearcpycreatepolyline','polyline.shp','POLYLINE')
    
    # 使用arcpy.da.InsertCursor类插入新创建的 点要素 到 点要素类
    insertCursor = arcpy.da.InsertCursor(polyline_featureClass, ['Shape@'])
    insertCursor.insertRow([line_Geometry])
    
    del insertCursor
    复制代码

    创建简单面要素、要素类

    复制代码
    #coding=utf-8
    import arcpy
    # 环的组成点集合
    points=[[0,0],[0,10],[10,10],[10,0],[0,0]]
    
    # 组成环的Array对象
    ring=arcpy.Array([arcpy.Point(*p) for p in points])
    
    # 创建features列表,用于存放要素,在内存
    features=[]
    # 通过ring(Array)创建Polygon对象
    # 将Polygon要素添加到features列表
    features.append(arcpy.Polygon(ring))
    
    # 调用复制要素工具,将内存中的features列表创建为shapefile
    arcpy.CopyFeatures_management(features, r"E:3 codingpy codearcpycreatepolygonpolygon.shp")
    复制代码

    创建多部件面要素、要素类

    创建一个多环面。

    内环的点可以是逆时针,也可以是顺时针的,在创建面的时候arcpy会自动处理拓扑,创建多环面。

    复制代码
    #coding=utf-8
    import arcpy
    # 3个环的组成点集合
    points1=[[0,0],[0,10],[10,10],[10,0],[0,0]]
    points2=[[2,2],[2,8],[8,8],[8,2],[2,2]]
    points3=[[4,4],[4,6],[6,6],[6,4],[4,4]]
    
    # 3个环的Array对象
    ring1=arcpy.Array([arcpy.Point(*p) for p in points1])
    ring2=arcpy.Array([arcpy.Point(*p) for p in points2])
    ring3=arcpy.Array([arcpy.Point(*p) for p in points3])
    
    # 创建features列表,用于存放要素,在内存
    features=[]
    # 通过Array组成的Array创建Polygon对象
    # 将Polygon要素添加到features列表
    features.append(arcpy.Polygon(arcpy.Array([ring1,ring2,ring3])))
    
    # 调用复制要素工具,将内存中的features列表创建为shapefile
    arcpy.CopyFeatures_management(features, r"E:3 codingpy codearcpycreatepolygonpolygon_multiPart.shp")
    复制代码

    作者:yzhyingcool
    博客:https://www.cnblogs.com/yzhyingcool/

  • 相关阅读:
    《那些年啊,那些事——一个程序员的奋斗史》——72
    《那些年啊,那些事——一个程序员的奋斗史》——74
    《那些年啊,那些事——一个程序员的奋斗史》——71
    《那些年啊,那些事——一个程序员的奋斗史》——72
    boost asio 学习(二)了解boost::bind
    boost asio 学习(四)使用strand将任务排序
    boost asio 网络聊天 代码修改学习
    asio 广播代码示例
    c++ 博客资源
    boost::asio 学习草稿
  • 原文地址:https://www.cnblogs.com/gisoracle/p/14824043.html
Copyright © 2020-2023  润新知