Describe (arcpy)

摘要

Describe 函数返回的 Describe 对象包含多个属性,如数据类型、字段、索引以及许多其他属性。该对象的属性是动态的,这意味着根据所描述的数据类型,会有不同的描述属性可供使用。

Describe 属性被组织成一系列属性组。任何特定数据集都将至少获取其中一个组的属性。例如,如果要描述一个地理数据库要素类,您可访问 GDB 要素类要素类数据集属性组中的属性。所有数据,不管是哪种数据类型,总会获取通用 Describe 对象属性。

讨论

许多数据类型包括其他属性组中的属性。例如,如果要描述一个地理数据库要素类,您可访问 GDB 要素类要素类数据集属性组中的属性。

注注:

在某些情况下,Describe 返回的对象并不包含为其设计的所有属性。例如,在 ArcMap 的内容列表中,图层的 describe 对象不会包含图层属性集。只有在描述 .lyr 文件时,该属性才会存在。

如果试图访问 Describe 对象不具有的属性,它会抛出错误异常或返回空值(无、0 或 -1 或空字符串)。如果您对特定属性不是很确定,可以使用 Python 的 hasattr() 函数进行检查。

语法

Describe (value)
参数说明数据类型
value

The specified data element or geoprocessing object to describe.

String
返回值
数据类型说明
Describe

返回具有用于详细描述所描述的数据元素的属性的对象。某些返回的对象属性会包含文本值或对象。

代码实例

Describe 属性示例(独立脚本)

以下独立脚本显示了脚本参数设置的图层中的一些图层和 describe 对象的属性。可针对 ArcMap 中的 .lyr 文件或图层设置该参数。

import arcpy

# Get the layer as a parameter and describe it.
#
# The layer could be a layer in ArcMap (like "some_layer")
# Or, it could be a .lyr file (like "C:/data/some.lyr")
#
layerString = arcpy.GetParameterAsText(0)
desc = arcpy.Describe(layerString)

# Print selected layer and describe object properties
# 
print "Name:", desc.name
if hasattr(desc, "layer"):
    print "Layer name:", desc.layer.name
    print "Layer data source:", desc.layer.catalogPath
    print ".lyr file:", desc.catalogPath
else:
    print "Layer name:", desc.name
    print "Layer data source:", desc.catalogPath

if desc.fidSet != '':
    print "Number of selected features:", str(len(desc.fidSet.split(";")))
5/10/2014