转置字段 (数据管理)

摘要

在新表或要素类中,将字段或列中存储的数据转换到行中。

当表或要素类在字段名(如 Field1Field2Field3)中存储值,并且您要将值转换为按行排列时,可使用该工具。这可以将字段名和字段中的相应数据值转换到行中。

插图

将表或要素类列中存储的数据值转置到行中
将表或要素类列中存储的数据值转置到行中。

使用情况

  • 默认情况下,输出为一张表。当输入为要素类而您希望输出也为要素类时,应在属性字段中添加 Shape 字段。

参数

标注说明数据类型
输入表

包含要转置的数据值字段的输入要素类或表。

Table View
要转置的字段

输入表中包含要进行转置的数据值的字段或列。

根据需要,可以选择多个要进行转置的字段。此处的值用于定义输出中的字段名。如果未指定,则值与字段名默认相同。不过,也可以指定您自己的值。例如,如果要转置的字段名是 Pop1991Pop1992 等,默认情况下,输出中这些字段的值将相同(Pop1991Pop1992 等)。但也可选择指定您自己的值,如 19911992

Value Table
输出表

输出要素类或表。输出将包含转置后的字段、值字段以及指定的需要从输入表继承的任意数量的属性字段。

默认情况下,输出表为一张表。当输入表为要素类,并且在属性字段参数中选择了 Shape 字段时,输出将为要素类。

Table
转置的字段

要创建的字段的名称,该字段用于存储已转置字段的字段名。可使用任何有效的字段名。

String
值字段

要创建的字段的名称,该字段用于存储已转置字段的相应值。可设置任何有效的字段名,只要它不与来自输入表或要素类的现有字段名冲突。

String
属性字段
(可选)

来自输入表的要被包含在输出表中的附加属性字段。如果要输出要素类,请添加 Shape 字段。

Field

arcpy.management.TransposeFields(in_table, in_field, out_table, in_transposed_field_name, in_value_field_name, {attribute_fields})
名称说明数据类型
in_table

包含要转置的数据值字段的输入要素类或表。

Table View
in_field
[[field, {value}],...]

输入表中包含要进行转置的数据值的字段或列。

根据需要,可以选择多个要进行转置的字段。此处的值用于定义输出中的字段名。如果未指定,则值与字段名默认相同。不过,也可以指定您自己的值。例如,如果要转置的字段名是 Pop1991Pop1992 等,默认情况下,输出中这些字段的值将相同(Pop1991Pop1992 等)。但也可选择指定您自己的值,如 19911992

Value Table
out_table

输出要素类或表。输出将包含转置后的字段、值字段以及指定的需要从输入表继承的任意数量的属性字段。

默认情况下,out_table 为一张表。当 in_table 为要素类,并且在 attribute_fields 参数中选择了 Shape 字段时,输出将为要素类。

Table
in_transposed_field_name

要创建的字段的名称,该字段用于存储已转置字段的字段名。可使用任何有效的字段名。

String
in_value_field_name

要创建的字段的名称,该字段用于存储已转置字段的相应值。可设置任何有效的字段名,只要它不与来自输入表或要素类的现有字段名冲突。

String
attribute_fields
[attribute_fields,...]
(可选)

来自输入表的要被包含在输出表中的附加属性字段。如果要输出要素类,请添加 Shape 字段。

Field

代码示例

TransposeFields 示例(Python 窗口)

以下 Python 窗口脚本演示了如何在即时模式下使用 TransposeFields 工具。

import arcpy
arcpy.TransposeFields_management("C:/Data/TemporalData.gdb/Input","Field1 newField1;Field2 newField2;Field3 newField3",
                                 "C:/Data/TemporalData.gdb/Output_Time","Transposed_Field", "Value","Shape;Type")
TransposeFields 示例 2(独立脚本)

以下独立脚本演示了如何使用 TransposeFields 工具。

# Name: TransposeFields_Ex_02.py
# Description: Tranpose field names from column headers to values in one column
# Requirements: None

# Import system modules
import arcpy
from arcpy import env

# set workspace
arcpy.env.workspace = "C:/Data/TemporalData.gdb"

# Set local variables
inTable = "Input"
# Specify fields to transpose
fieldsToTranspose = "Field1 newField1;Field2 newField2;Field3 newField3"
# Set a variable to store output feature class or table
outTable = "Output_Time"
# Set a variable to store time field name
transposedFieldName = "Transposed_Field"
# Set a variable to store value field name
valueFieldName = "Value"
# Specify attribute fields to be included in the output
attrFields = "Shape;Type"

# Execute TransposeTimeFields
arcpy.TransposeFields_management(inTable, fieldsToTranspose, outTable, transposedFieldName, valueFieldName, attrFields)