添加几何属性 (数据管理)

描述

向表示各要素空间或几何特性和位置的输入要素添加新的属性字段,如长度或面积或 x、y、z 和 m 坐标。

使用方法

    警告:

    此工具会修改输入数据。有关详细信息以及避免数据被意外更改的策略,请参阅修改或更新输入数据的工具

  • 它会向输入要素添加一个或多个属性字段,具体视几何属性参数中指定的选项而定。当输入要素中已经存在这些字段时,这些字段值将被覆盖。使用下表来确定要为各几何属性添加的字段:

    几何属性添加字段

    AREA

    POLY_AREA:面的面积。

    AREA_GEODESIC

    AREA_GEO:面的测地线面积。

    CENTROID

    CENTROID_X:质心点的 x 坐标。

    CENTROID_Y:质心点的 y 坐标。

    CENTROID_Z:质心点的 z 坐标。只有在输入要素启用了 z 值时,才会添加此字段。

    CENTROID_M:质心点的 m 坐标。只有在输入要素启用了 m 值时,才会添加此字段。

    CENTROID_INSIDE

    INSIDE_X:输入要素内或输入要素上中心点的 x 坐标。

    INSIDE_Y:输入要素内或输入要素上中心点的 y 坐标。

    INSIDE_Z:输入要素内或输入要素上中心点的 z 坐标。只有在输入要素启用了 z 值时,才会添加此字段。

    INSIDE_M:输入要素内或输入要素上中心点的 m 坐标。只有在输入要素启用了 m 值时,才会添加此字段。

    EXTENT

    EXT_MIN_X:要素的最小 x 坐标值。

    EXT_MIN_Y:要素的最小 y 坐标值。

    EXT_MAX_X:要素的最大 x 坐标值。

    EXT_MAX_Y:要素的最大 y 坐标值。

    长度

    LENGTH:线的长度。

    LENGTH_GEODESIC

    LENGTH_GEO:线的测地线长度。

    LENGTH_3D

    LENGTH_3D:线的 3D 长度。

    LINE_BEARING

    BEARING:线的起始-结束方位角。值范围介于 0 至 360 之间,其中 0 表示北,90 表示东,180 表示南,270 表示西,以此类推。

    LINE_START_MID_END

    START_X:线或面边框第一个点的 x 坐标。

    START_Y:线或面边框第一个点的 y 坐标。

    START_Z:线或面边框第一个点的 z 坐标。只有在输入要素启用了 z 值时,才会添加此字段。

    START_M:线或面边框第一个点的 m 坐标。只有在输入要素启用了 m 值时,才会添加此字段。

    MID_X:线或面边框长度中点的 x 坐标。

    MID_Y:线或面边框长度中点的 y 坐标。

    MID_Z:线或面边框长度中点的 z 坐标。只有在输入要素启用了 z 值时,才会添加此字段。

    MID_M:线或面边框长度中点的 m 坐标。只有在输入要素启用了 m 值时,才会添加此字段。

    END_X:线或面边框最后一个点的 x 坐标。

    END_Y:线或面边框最后一个点的 y 坐标。

    END_Z:线或面边框最后一个点的 z 坐标。只有在输入要素启用了 z 值时,才会添加此字段。

    END_M:线或面边框最后一个点的 m 坐标。只有在输入要素启用了 m 值时,才会添加此字段。

    PART_COUNT

    PART_COUNT:包含要素的部分数量。

    PERIMETER_LENGTH

    PERIMETER:面周长或边界长度。

    PERIMETER_LENGTH_GEODESIC

    PERIM_GEO:面周长或边界的测地线长度。

    POINT_COUNT

    PNT_COUNT:包含要素的点数。

    POINT_X_Y_Z_M

    POINT_X:点的 x 坐标。

    POINT_Y:点的 y 坐标。

    POINT_Z:点的 z 坐标。只有在输入要素启用了 z 值时,才会添加此字段。

    POINT_M:点的 m 坐标。只有在输入要素启用了 m 值时,才会添加此字段。

  • 如果已指定了坐标系,则长度和面积将以该坐标系的单位进行计算,除非在长度单位面积单位参数中选择了不同的单位。

  • 由此工具添加的属性字段与向要素层添加的字段相同。您可以覆盖字段值,也可以删除或重命名字段。编辑后,这些字段中的值不会自动重新计算。如果对要素进行了编辑,那么您需要再次运行此工具来更新字段值。

  • 如果输入要素具有选择内容,则在添加的字段中,仅所选要素具有计算值;其余所有要素的值均为空。

  • 此工具适用于点、多点、折线、面和注记要素类。注记被视为面要素类。

语法

arcpy.management.AddGeometryAttributes(Input_Features, Geometry_Properties, {Length_Unit}, {Area_Unit}, {Coordinate_System})
参数说明数据类型
Input_Features

将向输入要素添加新的属性字段以存储各种属性,如长度、面积或 x、y、z 和 m 坐标。

Feature Layer
Geometry_Properties
[Geometry_Properties,...]

确定将在新属性字段中进行计算的几何属性或形状属性。

  • AREA添加用于存储各个面要素面积的属性。
  • AREA_GEODESIC添加用于存储各个面要素测地线面积的属性。
  • CENTROID添加用于存储各个要素质点坐标的属性。
  • CENTROID_INSIDE添加用于存储各个要素内或要素上中心点坐标的属性。
  • EXTENT添加用于存储各个要素范围坐标的属性。
  • LENGTH添加用于存储各个线要素长度的属性。
  • LENGTH_GEODESIC添加用于存储各个线要素测地线长度的属性。
  • LENGTH_3D添加用于存储各个线要素 3D 长度的属性。
  • LINE_BEARING添加用于存储各个线要素线段起始-结束方位角的属性。值范围介于 0 至 360 之间,其中 0 表示北,90 表示东,180 表示南,270 表示西,以此类推。
  • LINE_START_MID_END添加用于存储各个要素起点、中点和终点坐标的属性。
  • PART_COUNT添加用于存储包含各个要素的部分数量的属性。
  • PERIMETER_LENGTH添加用于存储各个面要素周长或边界长度的属性。
  • PERIMETER_LENGTH_GEODESIC添加用于存储各个面要素周长或边界测地线长度的属性。
  • POINT_COUNT添加用于存储包含各个要素的点数或顶点数的属性。
  • POINT_X_Y_Z_M添加用于存储各个点要素 x、y、z 和 m 坐标的属性。
String
Length_Unit
(可选)

用以计算长度的单位。

  • FEET_US长度单位为英尺(美国)
  • METERS长度单位为米
  • KILOMETERS长度单位为千米
  • MILES_US长度单位为英里(美国)
  • NAUTICAL_MILES长度单位为海里(美国)
  • YARDS长度单位为码(美国)
String
Area_Unit
(可选)

用以计算面积的单位。

  • ACRES面积单位为英亩
  • HECTARES面积单位为公顷
  • SQUARE_MILES_US面积单位为平方英里(美国)
  • SQUARE_KILOMETERS面积单位为平方千米
  • SQUARE_METERS面积单位为平方米
  • SQUARE_FEET_US面积单位为平方英尺(美国)
  • SQUARE_YARDS面积单位为平方码(美国)
  • SQUARE_NAUTICAL_MILES面积单位为平方海里(美国)
String
Coordinate_System
(可选)

用于计算坐标、长度和面积的坐标系。默认使用输入要素的坐标系。

Coordinate System

派生输出

名称说明数据类型
Modified_Input_Features

已更新的输入要素。

要素图层

代码示例

AddGeometryAttributes 示例(Python 窗口)

下面的 Python 窗口脚本演示了如何使用 AddGeometryAttributes 工具。

import arcpy
arcpy.env.workspace = r"C:\data\City.gdb"
arcpy.AddGeometryAttributes_management("roads", "LENGTH;LINE_START_MID_END")
AddGeometryAttributes 示例(独立脚本)

获取各个线要素的范围矩形,并在该范围内构建一个 10 x 10 的栅格。

# Name: GridCreation.py
# import system modules
import arcpy
# Set environment settings
arcpy.env.workspace = r"C:\data\City.gdb"
arcpy.env.outputCoordinateSystem = arcpy.Describe("roads").spatialReference
# Set local variables
in_features = "roads"
properties = "EXTENT"
length_unit = ""
area_unit = ""
coordinate_system = ""
# Generate the extent coordinates using Add Geometry Properties tool
arcpy.AddGeometryAttributes_management(in_features, properties, length_unit,
                                                              area_unit,
                                                              coordinate_system)
# Use Search Cursor to walk through each feature and generate grids
with arcpy.da.SearchCursor(in_features, ["OID@", "EXT_MIN_X", "EXT_MIN_Y",
                                           "EXT_MAX_X", "EXT_MAX_Y"]) as sCur:
    for row in sCur:
        minX, minY, maxX, maxY = row[1], row[2], row[3], row[4]
        arcpy.CreateFishnet_management("fishnet_{0}".format(row[0]),
                    number_rows = 10,
                    number_columns = 10,
                    template = "{0} {1} {2} {3}".format(minX, maxX, minY, maxY),
                    origin_coord = "{0} {1}".format(minX, minY),
                    y_axis_coord = "{0} {1}".format(minX, maxY),
                    corner_coord = "{0} {1}".format(maxX, maxY),
                    geometry_type = "POLYGON",
                    labels = "NO_LABELS")

许可信息

  • Basic: 是
  • Standard: 是
  • Advanced: 是

相关主题