Что я должен сделать:
- переименовать имя поля таблицы / класса объектов
- скопировать все значения в новое поле
До сих пор я сделал следующий код, как подсказывает @ artwork21:
import sys
import traceback
import arcpy
from arcpy import env
## ARGUMENTS
# argv[1] = input table/feature class path
# argv[2] = input old field name
# argv[3] = input new field name
path = sys.argv[1]
oldFieldName = sys.argv[2]
newFieldName = sys.argv[3]
env.overwriteOutput = True
fields = arcpy.ListFields(path)
for field in fields:
if field.aliasName == oldFieldName:
if not oldFieldName == newFieldName:
fieldType = field.type
# Add new field
arcpy.AddField_management(path, newFieldName, fieldType)
#Calculates the new field based on old field values
arcpy.CalculateField_management(path, newFieldName, "!"+oldFieldName+"!", "PYTHON", "")
# Delete the old field (if necessary)
arcpy.DeleteField_management(path, oldFieldName)
Как я могу сопоставить field.type
с AddField_management
типом поля методы? И если поле находится посередине, то поле удаляется из середины и добавляется к последнему. Это не похоже на то, как будто имя поля переименовано.
Есть ли лучшее решение, которое поможет мне сделать эти вещи?
old_field
имя переменной или фактическое имя старого поля? Если это имя переменной, вам нужно использовать форматирование или конкатенацию строк, чтобы обернуть значение переменной в скобки (VB-анализатор) или восклицательные знаки (Python-анализатор).