Field

Summary

The field object represents a column in a table. A field has many properties, the most obvious ones being its name and its type.

Discussion

Field properties can be accessed through the ListFields and Describe functions.

Updating a field property only updates the field object, no changes are made to the actual field in the table or feature class.

Syntax

 Field  ()

Properties

PropertyExplanationData Type
aliasName
(Read and Write)

The alias name of the field.

String
baseName
(Read and Write)

The unqualified field name.

String
defaultValue
(Read and Write)

The default value of the field.

Variant
domain
(Read and Write)

The name of the associated domain.

String
editable
(Read and Write)

The editable state: True if the field is editable.

Boolean
isNullable
(Read and Write)

Indicates if the field can contain null values.

Boolean
length
(Read and Write)

The length of the field.

Integer
name
(Read and Write)

The name of the field.

String
precision
(Read and Write)

The precision for field values.

Integer
required
(Read and Write)

Indicates if the field is required. A required field cannot be deleted.

Boolean
scale
(Read and Write)

The scale of the field.

Integer
type
(Read and Write)

The field type.

  • BlobBlob
  • DateDate
  • DoubleDouble
  • GeometryGeometry
  • GlobalIDGlobal ID
  • GuidGuid
  • IntegerInteger (Long Integer)
  • OIDObject ID
  • RasterRaster
  • SingleSingle (Float)
  • SmallIntegerSmall Integer (Short Integer)
  • StringString (Text)
Note:

Although the Field object's type property values are not an exact match for the keywords used by the Add Field tool's field_type parameter, all of the Field object's type values can be used as input to this parameter. The different field types are mapped as follows: Integer to LONG, String to TEXT, and SmallInteger to SHORT.

String

Code sample

Field example

Display field properties for the specified feature class.

import arcpy

feature_class = "c:/data/counties.shp"

# Create a list of fields using the ListFields function
fields = arcpy.ListFields(feature_class)

# Iterate through the list of fields
for field in fields:
    # Print field properties
    print("Field:       {0}".format(field.name))
    print("Alias:       {0}".format(field.aliasName))
    print("Type:        {0}".format(field.type))
    print("Is Editable: {0}".format(field.editable))
    print("Required:    {0}".format(field.required))
    print("Scale:       {0}".format(field.scale))
    print("Precision:   {0}".format(field.precision))

Related topics