サマリー
Every tool parameter has an associated Parameter object with properties and methods that are useful in tool validation.
説明
Although many Parameter object properties are read/write, most of these properties can only be set or modified when you initially create or modify the object. Several properties, including name, displayName, datatype, direction, and parameterType, establish the characteristics of a tool and cannot be modified during validation methods (such as updateMessages and updateParameters).
構文
Parameter ({name}, {displayName}, {direction}, {datatype}, {parameterType}, {enabled}, {category}, {symbology}, {multiValue})
パラメーター | 説明 | データ タイプ |
name | The parameter name. (デフォルト値は次のとおりです None) | String |
displayName | The parameter label as shown in the Geoprocessing pane. (デフォルト値は次のとおりです None) | String |
direction | The direction of the parameter. (デフォルト値は次のとおりです Input) | String |
datatype | The data type of the parameter. For a list of parameter data types, see Geoprocessing data types. (デフォルト値は次のとおりです GPString) | String |
parameterType | The parameter type. (デフォルト値は次のとおりです Required) | String |
enabled | Specifies whether the parameter is visible in the Geoprocessing pane. (デフォルト値は次のとおりです True) | Boolean |
category | The category of the parameter. (デフォルト値は次のとおりです None) | String |
symbology | The path to a layer file (.lyrx or .lyr) used for drawing the output. (デフォルト値は次のとおりです None) | String |
multiValue | Specifies whether the parameter is a multivalue parameter. (デフォルト値は次のとおりです False) | Boolean |
プロパティ
プロパティ | 説明 | データ タイプ |
altered (読み取り専用) | Specifies whether the user has modified the value. | Boolean |
category (読み書き) | The category of the parameter. | String |
charts (読み書き) | A list of Chart objects that are added to an output parameter. | Object |
columns (読み書き) | The structure of the columns in a value table parameter. The columns are organized in a list of lists, with each inner list representing the column data type, column name, and an optional read-only value. If the read-only value is set to ReadOnly, the column cannot be modified by the user.
| String |
controlCLSID (読み書き) | A class identifier that can be used to override the default control for the data type. | String |
datatype (読み書き) | The data type of the parameter. For a list of parameter data types, see Geoprocessing data types. | String |
defaultEnvironmentName (読み書き) | The name of the geoprocessing environment setting used to set the parameter's default value. | String |
direction (読み書き) | The direction of the parameter.
| String |
displayName (読み書き) | The parameter label as shown in the Geoprocessing pane. | String |
displayOrder (読み書き) | The order in which a parameter displays in the Geoprocessing pane. This may be different from the order the parameters are accessed from Python. | Integer |
enabled (読み書き) | Specifies whether the parameter is visible in the Geoprocessing pane. | Boolean |
filter (読み取り専用) | The filter to apply to values in the parameter. | Filter |
filters (読み書き) | Similar to the filter property, but it is used to support value table and composite parameters. For a value table parameter, set the filters property, and define a Filter object using the list and optional type for each column in the value table.
For a composite parameter, set the filters property, and define a Filter object using a list for each data type in the composite parameter.
| Filter |
hasBeenValidated (読み取り専用) | Specifies whether the internal validation routine has checked the parameter. | Boolean |
message (読み取り専用) | The message to be displayed to the user. | String |
multiValue (読み書き) | Specifies whether the parameter is a multivalue parameter. | Boolean |
name (読み書き) | The parameter name. | String |
parameterDependencies (読み書き) | A list of indexes of each dependent parameter. In a script tool, parameterDependencies is set with a list of parameter indexes; in a Python toolbox tool, parameterDependencies is set with a list of parameter names. | Integer |
parameterType (読み書き) | The parameter type.
For derived parameters, set the direction property to Output and the parameterType property to Derived. 検証では、parameterType の値を動的に変更できません。 ただし、他のパラメーター設定によっては、パラメーターが必須のパラメーターまたはオプションのパラメーターとして機能する必要があります。 その場合、パラメーターをオプションとして設定します。 次に、検証の updateMessages メソッドで、Parameter setIDMessage メソッドをメッセージ ID 530 または 735 とともに使用します。 メッセージ ID 530 または 735 を使用すると、オプションのパラメーターが必須のパラメーターとして機能します。 | String |
schema (読み取り専用) | The schema of the output dataset. | Schema |
symbology (読み書き) | The path to a layer file (.lyrx or .lyr) used for drawing the output. | String |
value (読み書き) | The value of the parameter. | Object |
valueAsText (読み取り専用) | The value of the parameter as a string. | String |
values (読み書き) | The values of a Value Table parameter, which is set using a list of lists. | Variant |
方法の概要
方法 | 説明 |
clearMessage () | Clears out any message text and sets the status to informative (no error or warning). |
hasError () | Returns True if the parameter contains an error. To evaluate whether a parameter has an error, hasError should be called within the tool validation's updateMessages method. |
hasWarning () | Returns True if the parameter contains a warning. |
isInputValueDerived () | Returns True if the tool is being validated inside a Model and the input value is the output of another tool in the model. |
setErrorMessage (message) | Sets a parameter as having an error with the supplied message. Tools do not execute if any of the parameters have an error. |
setIDMessage (message_type, message_ID, {add_argument1}, {add_argument2}) | Sets a parameter as having a system message. |
setWarningMessage (message) | Sets a parameter as having an error with the supplied message. Unlike errors, tools will execute with warning messages. |
方法
clearMessage ()
hasError ()
データ タイプ | 説明 |
Boolean | True if the parameter contains an error. |
hasWarning ()
データ タイプ | 説明 |
Boolean | True if the parameter contains a warning. |
isInputValueDerived ()
データ タイプ | 説明 |
Boolean | True if the tool is being validated inside a Model and the input value is the output of another tool in the model. |
setErrorMessage (message)
パラメーター | 説明 | データ タイプ |
message | The string to be added as an error message to the geoprocessing tool messages. | String |
setIDMessage (message_type, message_ID, {add_argument1}, {add_argument2})
パラメーター | 説明 | データ タイプ |
message_type | Defines whether the message will be an error or a warning.
| String |
message_ID | The message ID allows you to reference existing system messages. | Integer |
add_argument1 | Depending on which message ID is used, an argument may be necessary to complete the message. Common examples include dataset or field names. The data type is variable depending on the message. | Object |
add_argument2 | Depending on which message ID is used, an argument may be necessary to complete the message. Common examples include dataset or field names. The data type is variable depending on the message. | Object |
setWarningMessage (message)
パラメーター | 説明 | データ タイプ |
message | The string to be added as a warning message to the geoprocessing tool messages. | String |
コードのサンプル
Enable or disable a parameter in a ToolValidator class.
def updateParameters(self):
# If the option to use a weights file ("Get Spatial Weights From File")
# is selected, enable the parameter for specifying the file;
# otherwise, disable it.
if self.params[3].value == "Get Spatial Weights From File":
self.params[8].enabled = True
else:
self.params[8].enabled = False
return
Set a default value for a parameter in a ToolValidator class.
def updateParameters(self):
# Set the default distance threshold to 1/100 of the larger of
# the width or height of the extent of the input features. Do
# not set if there is no input dataset yet, or the user has set
# a specific distance (Altered is true).
if self.params[0].value:
if not self.params[6].altered:
extent = arcpy.Describe(self.params[0].value)
width = extent.XMax - extent.XMin
height = extent.YMax - extent.YMin
if width < height:
self.params[6].value = width / 100
else:
self.params[6].value = height / 100
return
Set a custom error message for a parameter in a ToolValidator class.
def updateMessages(self):
self.params[6].clearMessage()
# Check whether the threshold distance contains a value of
# zero and the user has specified a fixed distance band.
if self.params[6].value <= 0:
if self.params[3].value == "Fixed Distance Band":
self.params[6].setErrorMessage(
"Zero or a negative distance is invalid when "
"using a fixed distance band. Please use a "
"positive value greater than zero.")
elif self.params[6].value < 0:
self.params[6].setErrorMessage(
"A positive distance value is required when "
"using a fixed distance band. Be sure to specify "
"a distance.")
return