Summary
The schema of a dataset.
Discussion
Every output parameter of type feature class, table, raster, or workspace has a Schema object. Only output feature classes, tables, rasters, and workspaces have a schema—other types do not. The Schema object is created in geoprocessing tool validation. You access this schema through the parameter object and set the rules for describing the output of the tool. After you set the schema rules in validation, the geoprocessing internal validation code examines the rules you set and updates the description of the output.
Properties
| Property | Explanation | Data Type |
| additionalChildren (Read and Write) | A list of datasets that will be added to a workspace schema. | String |
| additionalFields (Read and Write) | Additional fields that will be created by the tool. These fields are in addition to those added by the application of the fieldsRule property. | Field |
| cellSize (Read and Write) | The cell size of the output. Use this property when the cellSizeRule property value is AsSpecified. | Double |
| cellSizeRule (Read and Write) | Specifies the cell size of output rasters or grids.
| String |
| clone (Read and Write) | Specifies whether an exact copy (clone) of the description in the first dependent parameter will be used. The default value is False. | Boolean |
| extent (Read and Write) | The extent that will be used when the extentRule property value is AsSpecified. The extent can be set with a space-delimited string or a list with four values. The sequence is the minimum x, the minimum y, the maximum x, and the maximum y. | Extent |
| extentRule (Read and Write) | Specifies how the extent property will be managed.
| String |
| featureType (Read and Write) | Specifies the feature type of the output when the featureTypeRule property value is AsSpecified.
| String |
| featureTypeRule (Read and Write) | Specifies the feature type of the output feature class. This rule has no effect on output rasters or tables.
| String |
| fieldsRule (Read and Write) | Specifies the fields that will exist on the output feature class or table.
| String |
| geometryType (Read and Write) | Specifies the geometry type of the output. The value can be Point, Multipoint, Polyline, or Polygon when the geometryTypeRule property value is AsSpecified. | String |
| geometryTypeRule (Read and Write) | Specifies the geometry type (such as point or polygon) of the output feature class.
| String |
| rasterFormatRule (Read and Write) | Specifies the output raster format, either GRID or Img. The default is Img, which is ERDAS IMAGINE format. | String |
| rasterRule (Read and Write) | Specifies the data type that will be contained in the output raster.
| String |
| type (Read Only) | Specifies the output schema type: Feature, Table, Raster, or Container (for workspaces and feature datasets). | String |
Code sample
In a ToolValidator class, set the schema of the output parameter to the first input parameter.
def initializeParameters(self):
# Set the dependencies for the output and its schema properties. The two
# input parameters are feature classes.
self.params[2].parameterDependencies = [0, 1]
# Feature type, geometry type, and fields all come from the first dependency
# (parameter 0), the input features.
self.params[2].schema.featureTypeRule = "FirstDependency"
self.params[2].schema.geometryTypeRule = "FirstDependency"
self.params[2].schema.fieldsRule = "FirstDependency"
# The extent of the output is the intersection of the input features and
# the clip features (parameter 1).
self.params[2].schema.extentRule = "Intersection"
returnInterrogate the schema of a specific tool output parameter using the GetParameterInfo function.
import arcpy
toolname = "Buffer_analysis"
parameter_index = 1
# Get the schema of the tool parameter
schema = arcpy.GetParameterInfo(toolname)[parameter_index].schema
properties = ['additionalChildren', 'additionalFields', 'cellSize',
'cellSizeRule', 'clone', 'extent', 'extentRule',
'featureType', 'featureTypeRule', 'fieldsRule',
'geometryType', 'geometryTypeRule', 'rasterFormatRule',
'rasterRule', 'type']
# Walk through all schema properties and print the value
for prop in properties:
try:
val = eval("schema." + prop)
print("{:<18} : {}".format(prop, val))
except (NameError, RuntimeError):
# Properties unsupported by the parameter data type will be ignored
pass