マージツールは、簡単に再注文のフィールドを永続的にすることができます。テーブルとフィーチャクラスで機能します。並べ替えは、Pythonスクリプトを介して行うことも、[ツール]ダイアログを使用して行うこともできます(フィールドを削除して、ダイアログで再度追加することにより)。ダイアログを介した並べ替えは完璧なアプローチではありませんが。
マージツールを1回使用してから、[ Pythonスニペットとしてコピー]を使用し、フィールドの順序を手動で変更してから、PythonウィンドウにPythonコードを貼り付けることをお勧めします。
以下は、マージツールを使用してフィールドを並べ替えるpythonスクリプトです(ここからコピーします)
import arcpy
def reorder_fields(table, out_table, field_order, add_missing=True):
"""
Reorders fields in input featureclass/table
:table: input table (fc, table, layer, etc)
:out_table: output table (fc, table, layer, etc)
:field_order: order of fields (objectid, shape not necessary)
:add_missing: add missing fields to end if True (leave out if False)
-> path to output table
"""
existing_fields = arcpy.ListFields(table)
existing_field_names = [field.name for field in existing_fields]
existing_mapping = arcpy.FieldMappings()
existing_mapping.addTable(table)
new_mapping = arcpy.FieldMappings()
def add_mapping(field_name):
mapping_index = existing_mapping.findFieldMapIndex(field_name)
# required fields (OBJECTID, etc) will not be in existing mappings
# they are added automatically
if mapping_index != -1:
field_map = existing_mapping.fieldMappings[mapping_index]
new_mapping.addFieldMap(field_map)
# add user fields from field_order
for field_name in field_order:
if field_name not in existing_field_names:
raise Exception("Field: {0} not in {1}".format(field_name, table))
add_mapping(field_name)
# add missing fields at end
if add_missing:
missing_fields = [f for f in existing_field_names if f not in field_order]
for field_name in missing_fields:
add_mapping(field_name)
# use merge with single input just to use new field_mappings
arcpy.Merge_management(table, out_table, new_mapping)
return out_table
使用法:
new_field_order = ["field2", "field3", "field1"]
reorder_fields(in_fc, out_fc, new_field_order)