概要
テーブル、フィーチャクラス、フィーチャ レイヤー、またはラスター データセットから 1 つ以上のフィールドを削除します。
使用法
- このツールは、任意のテーブル (エンタープライズ、ファイル、またはパーソナル ジオデータベース フィーチャクラス、カバレッジ、ラスター データセット、シェープファイル) で使用できます。 
- フィールドは、VPF や CAD データセットなど、ArcGIS で非ネイティブの読み取り専用データ形式からは削除できません。 
- [削除するフィールド] パラメーターの [フィールドの追加] ボタンは、ModelBuilder だけで使用されます。ModelBuilder では、先のツールが実行されていないか、出力データが存在しないために、[削除するフィールド] パラメーターにフィールド名が表示されない場合があります。[フィールドの追加] ボタンを使用すると、[フィールドの削除] ダイアログ ボックスを完了してモデルの作成を続行できるように、必要なフィールドを追加することができます。 
構文
arcpy.management.DeleteField(in_table, drop_field)
| パラメーター | 説明 | データ タイプ | 
| in_table | 削除するフィールドを含むテーブル。既存の入力テーブルが変更されます。 | Mosaic Layer; Raster Catalog Layer; Raster Layer; Table View | 
| drop_field [drop_field,...] | 入力テーブルから削除するフィールド。不要なフィールドのみを削除できます。 | Field | 
コードのサンプル
DeleteField (フィールドの削除) の例 (Python ウィンドウ)
次の Python ウィンドウ スクリプトは、DeleteField ツールをイミディエイト モードで使用する方法を示しています。
import arcpy
arcpy.env.workspace = "C:/data"
arcpy.CopyFeatures_management("majorrds.shp", "C:/output/majorrds_copy.shp")
arcpy.DeleteField_management("C:/output/majorrds_copy.shp", 
                             ["STREET_NAM", "LABEL", "CLASS"])
DeleteField (フィールドの削除) の例 2 (スタンドアロン スクリプト)
次のスタンドアロン スクリプトで、この DeleteField ツールの使用方法を示します。
# Name: DeleteField_Example2.py
# Description: Delete several fields from a feature class
  
# Import system modules
import arcpy
 
# Set environment settings
arcpy.env.workspace = "C:/data"
 
# Set local variables
inFeatures = "accident.dbf"
outFeatureClass = "C:/output/new_accident.dbf"
dropFields = ["STREET_NAM", "LABEL", "CLASS"]
 
# Execute CopyFeatures to make a new copy of the feature class
#  Use CopyRows if you have a table
arcpy.CopyFeatures_management(inFeatures, outFeatureClass)
 
# Execute DeleteField
arcpy.DeleteField_management(outFeatureClass, dropFields)
DeleteField (フィールドの削除) の例 3 (スタンドアロン スクリプト)
DeleteField を使用して、フィーチャクラスまたはテーブルから不要なすべてのフィーチャを消去します。
# Name: DeleteFields_clearfields.py
# Description: Delete unrequired fields from a feature class or table.
 
# Import system modules
import arcpy
 
try: 
    # Get user-supplied input and output arguments
    inTable = arcpy.GetParameterAsText(0)
    updatedTable = arcpy.GetParameterAsText(1)
 
    # Describe the input (need to test the dataset and data types)
    desc = arcpy.Describe(updatedTable)
 
    # Make a copy of the input (so we can mantain the original as is)
    if desc.datasetType == "FeatureClass":
        arcpy.CopyFeatures_management(inTable, updatedTable)
    else:
        arcpy.CopyRows_management(inTable, updatedTable)
 
    # Use ListFields to get a list of field objects
    fieldObjList = arcpy.ListFields(updatedTable)
 
    # Create an empty list that will be populated with field names        
    fieldNameList = []
 
    # For each field in the object list, add the field name to the
    #  name list.  If the field is required, exclude it, to prevent errors
    for field in fieldObjList:
        if not field.required:
            fieldNameList.append(field.name)
 
    # dBASE tables require a field other than an OID and Shape.  If this is
    #  the case, retain an extra field (the first one in the original list)
    if desc.dataType in ["ShapeFile", "DbaseTable"]:
        fieldNameList = fieldNameList[1:]
 
    # Execute DeleteField to delete all fields in the field list. 
    arcpy.DeleteField_management(updatedTable, fieldNameList)
          
except Exception as err:
    print(err.args[0])
環境
ライセンス情報
- Basic: はい
- Standard: はい
- Advanced: はい