Для общего обзора класса ToolValidator и использования методов параметров, см. раздел Настройка поведения инструмента-скрипта.
Объект Parameter
Доступ к параметрам инструмента
Каждый параметр инструмента имеет связанный с ним объект параметра, у которого есть свойства и методы для проверки корректности параметров инструмента. Параметры содержатся в списке . Обычной практикой является создание списка параметров в классе ToolValidator метода __init__, как показано в приведенном ниже программном коде.
def __init__(self):
self.params = arcpy.GetParameterInfo()
Вы также можете управлять параметрами в своем скрипте (как альтернатива классу ToolValidator), как показано ниже. Единственная причина для доступа к списку параметров внутри скрипта – это задание свойства symbology.
params = arcpy.GetParameterInfo()
Порядок параметров
Параметры инструмента и их порядок описаны на вкладке Параметры в свойствах инструмента, как показано ниже.
Примечание:
Список параметров начинается с нуля, поэтому первый параметр идет на нулевом месте в списке. Для доступа к третьему параметру вам нужно ввести p3 = self.params[2].
Методы
Имя метода | Описание использования |
---|---|
setErrorMessage(message) | Отмечает параметр, как имеющий ошибку (), с добавленным сообщением. Инструменты не выполняются, если один из параметров имеет ошибку. |
setWarningMessage(message) | Отмечает параметр, как имеющий предупреждение (), с добавленным сообщением. В отличие от ошибок, инструменты с предупреждениями выполняются. |
setIDMessage(messageType, messageID, {AddArgument1}, {AddArgument2}) | Позволяет вам задать системное сообщение. Аргументы те же, что и у функции AddIDMessage. |
clearMessage() | Очищает любой текст сообщения и устанавливает статус на информативность (не ошибка и не предупреждение). |
hasError() | Возвращает значение true, если параметр содержит ошибку. |
hasWarning() | Возвращает значение true, если параметр содержит предупреждение. |
isInputValueDerived() | Возвращает значение true, если инструмент был проверен внутри модели, и его входное значение является выходным значением другого инструмента данной модели. |
Свойства
Имя свойства | Чтение/Запись | Значение | Описание |
---|---|---|---|
name | Только для чтения | String | Имя параметра, как задано на вкладке Параметры в свойствах инструмента. |
direction | Только для чтения | String: "Input", "Output" | Направление параметра Входной/Выходной, как задано на вкладке Параметры в свойствах инструмента. |
datatype | Только для чтения | String | Тип данных, как задано на вкладке Параметры в свойствах инструмента. |
Только для чтения | String: "Required", "Optional", "Derived" | Тип, как задано на вкладке Параметры в свойствах инструмента. | |
Чтение/запись | Список | Список индексов каждого зависимого параметра. | |
Чтение/запись | Объект Value | Значение параметра. | |
defaultEnvironmentName | Только для чтения | String | Настройка переменной среды по умолчанию, как задано на вкладке Параметры в свойствах инструмента. |
enabled | Чтение/запись | Boolean | False, если параметр недоступен. |
Только для чтения | Boolean | True, если пользователь изменил значение. | |
Только для чтения | Boolean | True, если параметр был проверен внутренней процедурой проверки. | |
Чтение/запись | String | Категория параметра. | |
Только для чтения | Объект Schema | Схема выходного набора данных. | |
Только для чтения | Объект Filter | Фильтр, применяемый к значениям параметра. | |
Чтение/запись | String | Путь к файлу слоя (.lyrx), используемому для отображения выходных данных. | |
message | Только для чтения | String | Сообщение, показываемое пользователю. См. методы setErrorMessage и setWarningMessage выше. |
Хотя многие свойства объекта Parameter доступны для чтения и записи, большинство из них можно задать или изменить только при первоначальном создании или изменении объекта. Некоторые свойства, включая name, displayName, datatype, direction и parameterType, устанавливают характеристики инструмента и не могут быть изменены во время проверки (например, updateMessages и updateParameters).
Некоторые примеры кодов показаны ниже. Для получения других примеров кодов, см. раздел Настройка поведения инструмента-скрипта.
Сравнение свойств ToolValidator со свойствами инструментов-скриптов
Можно задать значение параметра по умолчанию, фильтр, символ и зависимости на вкладке Параметры в диалоговом окне свойств инструмента-скрипта и в классе ToolValidator.
Свойства, которые вы установите в классе ToolValidator, всегда будут заменять собой те значения, которые были заданы в диалоговом окне свойств инструмента-скрипта. Например, если вы установили значение по умолчанию для параметра равным "BLUE" в диалоговом окне свойств инструмента-скрипта, и переустановили его на "RED" в initializeParameters, значением по умолчанию станет "RED". Как только был вызван метод initializeParameters, диалоговое окно свойств инструмента-скрипта будет отображать "RED" в качестве значения по умолчанию. Если вы (или ваши пользователи) попадете в ситуацию, когда сделанные изменения для одного из этих четырех свойств параметра в диалоговом окне свойств скрипта не сохраняются, это может быть связано с тем, что свойство было переопределено в классе ToolValidator.
parameterDependencies
Как правило, вы устанавливаете набор зависимостей параметра для использования объектом Schema. В следующих двух случаях зависимость уже может быть установлена на вкладке Параметры в диалоговом окне свойств инструмента:
- Для параметра выходного набора данных, производного типа, зависимостью является индекс параметра, из которого извлекаются выходные данные.
- Для определенных типов входных данных, зависимостью является индекс параметра, содержащий информацию, используемую элементом управления, как показано в таблице ниже.
Тип данных параметра | Тип данных зависимого параметра |
---|---|
Единица площади | Географический набор данных, используемый для определения единиц измерения по умолчанию. Например, можно использовать тип данных Векторный слой или Растровый слой. |
Поле | Таблица, содержащая поля. Например, можно использовать тип данных Представление таблицы, Векторный слой или Растровый слой. |
Сопоставление полей | Набор полей в одной или более входных таблицах. Например, можно использовать тип данных Представление таблицы, Векторный слой или Растровый слой. |
Таблица геостатистических значений | Таблица наборов данных и полей, используемых в инструментах Geostatistical Analyst. Используйте тип данных Геостатистический слой. |
Линейные единицы измерения | Географический набор данных, используемый для определения единиц измерения по умолчанию. Например, можно использовать тип данных Векторный слой или Растровый слой. |
Настройки иерархии Network Analyst | Набор сетевых данных, содержащий информацию об иерархии. Используйте тип данных Набор сетевых данных. |
Режим передвижения по сети | Список режимов передвижения. Используйте тип данных Источник сетевых данных, Набор сетевых данных или Слой набора сетевых данных. |
Выражение SQL | Таблица, содержащая поля. Например, можно использовать тип данных Представление таблицы, Векторный слой или Растровый слой. |
Зависимости обычно устанавливаются в методе initializeParameters:
def initializeParameters(self):
# Set the dependencies for the output and its schema properties
self.params[2].parameterDependencies = [0, 1]
parameterType
Свойство parameterType может быть обязательным, необязательным и производным.
- Обязательное — значение необходимо для работы инструмента.
- Необязательное — значение не является необходимым для работы инструмента.
- Производное — выходное значение, которое не указано в качестве входного параметра. Производные параметры всегда являются выходными параметрами.
При проверке значение parameterType не может быть динамически изменено. Однако может потребоваться, чтобы параметр соответствовал обязательному или необязательному, в зависимости от настроек других параметров. В этом случае установите параметр как дополнительный. Затем в методе проверки updateMessages используйте метод Parameter setIDMessage с идентификатором сообщения 735. Использование идентификатора сообщения 735 приводит к тому, что необязательный параметр ведет себя как обязательный параметр.
# Force a parameter to be required using setIDMessage, if the preceding
# parameter does not have a value.
if not self.params[4].valueAsText:
self.params[5].setIDMessage('ERROR', 735)
value
Это значение параметра, которое ввел пользователь, или которое было задано вами программно. Вы можете установить значение в методе initializeParameters, и в этом случае оно выступит в качестве начального значения по умолчанию для параметра. Вы также можете установить значения в updateParameters в ответ на ввод значения пользователем, как показано ниже.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].valueAsText:
if not self.params[6].altered:
extent = arcpy.Describe(self.params[0]).extent
if extent.width > extent.height:
self.params[6].value = extent.width / 100
else:
self.params[6].value = extent.height / 100
return
Свойство value параметра возвращает объект, кроме случая, когда параметр не заполнен, в этом случае value возвращает значение None. Чтобы убедиться, что параметр заполнен, используйте проверку if перед использованием его значения.
Фрагмент кода ниже тестирует, является ли значение идентичным строке "Get Spatial Weights From File". Данный тест работает, поскольку тип данных параметра является строковым.
# If the option to use a weights file is selected, enable the
# parameter for specifying the file, otherwise disable it
if self.params[3].value: # check that parameter has a value
if self.params[3].value == "Get Spatial Weights From File":
self.params[8].enabled = True
else:
self.params[8].enabled = False
Поскольку объект Value не поддерживает манипуляции со строками, используйте свойство значения объекта Value всякий раз, когда требуется обработать или проанализировать строку. Пример кода ниже использует метод os.path.dirname, чтобы вернуть директорию для набора данных.
if self.params[0].value:
workspace = os.path.dirname(self.params[0].value.value)
Внимание:
За исключением метода Describe, не используйте для проверки методы, берущие путь к каталогу, такие как ListFields. Набор данных может не существовать, когда проверка инструмента осуществляется в ModelBuilder, и метод может дать сбой или выдать непредсказуемый результат.
Describe можно использовать для объекта Parameter вместо использования свойства value параметра. Использование свойства value возможно, но оно будет работать медленнее при работе со входными слоями.
В конкретном случае метода ListFields, Describe свойство объекта fields предоставит эквивалентную информацию.
Внимание:
Не устанавливайте значение параметра в updateMessages, пока это значение не будет проверено внутренней подпрограммой проверки.
altered
altered равно true, если изменено значение параметра, например, путем ввода выходного пути. Если параметр был изменен, то он остается измененным, пока пользователь не очистит (не удалит) значение, в этом случае оно вернется к изначальному неизмененному состоянию. Изменение значения программным способом с проверкой кода будет влиять на измененный статус. То есть, если вы установите значение для параметра, измененный статус параметра будет обновляться.
altered используется, чтобы определить, можете ли вы изменить значение параметра. Например, предположим, что у инструмента есть параметр класс объектов и параметр ключевое слово. Если класс объектов содержит точки или полигоны, то ключевыми словами будут Красный (RED), Зеленый (GREEN), и Синий (BLUE), а если линии – то Оранжевый (ORANGE), Желтый (YELLOW), Фиолетовый (PURPLE), и Белый (WHITE).
Предположим, пользователь вводит точечный класс объектов. Если параметр ключевое слово не изменен, вы устанавливаете значение на RED, поскольку оно является значением по умолчанию.
Если вводится линейный класс объектов, вы устанавливаете значение на ORANGE, поскольку параметр ключевое слово не изменен.
Однако, если параметр ключевое слово был изменен пользователем (например, ключевое слово установлено на GREEN), не меняйте обратно ключевое слово. Пользователь сделал свой выбор (GREEN), и вы не знаете его намерений. Он мог поменять класс объектов, и тогда GREEN будет корректным значением, или он мог поменять ключевое слово (на PURPLE, например). Поскольку GREEN не входит в набор ключевых слов, которые вы создали для линий, внутренняя проверка установит на параметре отметку ошибки. У пользователя будет два варианта действий: изменить входной класс объектов или изменить ключевое слово.
if not self.params[2].altered:
self.params[2].value = "POINT"
hasBeenValidated
hasBeenValidated равно False, если значение параметра было изменено пользователем с того момента, когда updateParameters и внутренняя проверка вызывались в последний раз. После вызова внутренней процедуры проверки, процедура геообработки автоматически устанавливает hasBeenValidated равным True для каждого параметра.
hasBeenValidated используется для определения, изменял ли пользователь значение с момента последнего запуска updateParameters. Эта информация необходима при решении вопроса о необходимости проверки параметра.
# 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 if the input features have already been validated,
# or the user has set a specific distance (Altered is true).
if self.params[0].valueAsText and not self.params[0].hasBeenValidated:
if not self.params[6].altered:
extent = arcpy.Describe(self.params[0]).extent
width = extent.width
height = extent.height
if width > height:
self.params[6].value = width / 100
else:
self.params[6].value = height / 100
категория
Параметры могут быть сгруппированы в категории на панели Геообработка, чтобы минимизировать размер параметров, или в связанные с группой параметры, которые будут редко использоваться. Несколько инструментов ArcGIS Network Analyst extension используют категории как показано ниже.
Поскольку вы можете задать категорию только один раз, задайте ее в initializeParameters. Задание категорий в updateParameters не даст никакого эффекта. Код, приведенный ниже, показывает размещение параметров 4 и 5 в категории Options, и параметров 6 и 7 в категории Advanced.
def initializeParameters(self):
self.params[4].category = "Options"
self.params[5].category = "Options"
self.params[6].category = "Advanced"
self.params[7].category = "Advanced"
Категории всегда идут после параметров, не помещенных в категорию. Не распределяйте обязательные параметры по категориям, поскольку пользователь может не увидеть их на панели Геообработка.
символы
Свойство symbology связывает файл слоя (.lyrx) с выходным параметром.
params[2].symbology = "E:/tools/extraction/ToolData/ClassByDist.lyrx"
объект схема
У каждого выходного параметра следующих типов: класс пространственных объектов, таблица, растр или рабочая область – есть объект схемы. Только у выходных классов пространственных объектов, таблиц, растров и рабочих областей есть объект схемы; у других типов его нет. Объект схемы создается автоматически процессом геообработки. К схеме осуществляется доступ через объект 'параметр', и устанавливаются правила для описания выходных данных инструмента. После установки правил схемы и в качестве выходного результата класса ToolValidator, код внутренней проверки геообработки анализирует эти правила и обновляет описание выходных данных.
Для проверки, настройка заключается в следующем:
- Во время первого открытия инструмента на панели Геообработка вызывается initializeParameters. Для описания выходных данных устанавливаются статические правила (правила, которые не изменяются вводимыми пользователем данными). На этом этапе не создается описания на выходе, так как пользователь не указал значения ни для одного из параметров (если вы не задали значений по умолчанию).
- Как только пользователь начинает как-либо работать с инструментом на панели Геообработка, происходит вызов updateParameters.
- updateParameters может изменить объект схемы с учетом динамического поведения, которое нельзя установить с помощью параметрических зависимостей (например, добавление нового поля с помощью Добавить поле).
- После возврата из updateParameters запускаются подпрограммы внутренней проверки, а правила, найденные в объекте схемы, применяются для обновления описания выходных данных.
- Затем происходит вызов updateMessages. Вы можете изучить предупреждения и сообщения об ошибках, которые выводятся внутренней процедурой оценки, и изменить их или добавить пользовательские предупреждения или сообщения об ошибках.
Все свойства schema доступны для чтения и записи, за исключением type, которое доступно только для чтения.
Имя свойства | Значение |
---|---|
type | String: "Feature", "Table", "Raster" , "Container" (для рабочих областей и наборов данных объектов) |
clone | Boolean |
featureTypeRule | String: "AsSpecified", "FirstDependency" |
featureType | String: "Simple", "Annotation", "Dimension" |
geometryTypeRule | String: "Unknown", "FirstDependency", "Min", "Max", "AsSpecified" |
geometryType | String: "Point", "Multipoint", "Polyline", "Polygon" |
extentRule | String: "AsSpecified", "FirstDependency", "Intersection", "Union", "Environment" |
extent | Объект Extent |
fieldsRule | String: "None", "FirstDependency", "FirstDependencyFIDs", "All", "AllNoFIDs", "AllFIDsOnly" |
additionalFields | Список объектов Field |
cellSizeRule | String: "AsSpecified", "FirstDependency", "Min", "Max", "Environment" |
cellSize | Double |
rasterRule | String: "FirstDependency", "Min", "Max", "Integer", "Float" |
rasterFormatRule | String: "Img", "Grid" |
additionalChildren | Список наборов данных для добавления в схему рабочей области |
Используйте FirstDependency
Некоторые из правил могут быть установлены на "FirstDependency", что означает, что будет использовано значение первого параметра, найденного в наборе массива зависимостей параметров, заданного с помощью parameter.parameterDependencies. В примере кода, приведенном ниже, параметр 2 имеет два зависимых параметра, 0 и 1, и первой зависимостью является параметр 0.
# Set the dependencies for the output and its schema properties
self.params[2].parameterDependencies = [0, 1]
Если любой зависимый параметр содержит несколько значений (список значений), будет использовано первое значение из списка.
type
Свойство type доступно только для чтения, и устанавливается процессом геообработки.
clone
При истинном значении процедура геообработки создаст точную копию (клон) описания в первом зависимом параметре. Значение по умолчанию – false. Обычно вы устанавливаете параметр clone равным True (истина) в методе initializeParameters. Если первый зависимый параметр является многозначным (список значений), клонируется первое значение в многозначном списке значений.
- Если parameter.parameterType равен "Производный", будет создана точная копия. Это было поведение инструмента Добавить поле.
- Если значением parameter.parameterType является "Обязательный", то будет создана точная копия, но путь к каталогу, содержащему набор данных, будет изменен. Пути каталога состоят из двух частей: рабочая область и базовое имя, например E:/Data/TestData/netcity.gdb/infrastructure/roads.
- Рабочая область = E:/Data/TestData/netcity.gdb/infrastructure
- Исходное имя = roads
- Базовое имя является тем же, что и базовое имя для первого входного параметра, содержащего набор данных (не первой зависимости, но первого параметра), с добавленным именем инструмента-скрипта (например, roads_MyTool).
- Рабочей области присвоены настройки параметров среды временной рабочей области. Если она пустая, то используются настройки параметров среды текущей рабочей области. Если она также пуста, то используется рабочая область первого входного параметра, содержащего набор данных. Если рабочая область установлена только на чтение, то используется системная временная директория.
После установки clone на true все методы, основанные на правилах, такие как featureTypeRule, geometryTypeRule и extentRule, устанавливаются на значение "FirstDependency".
Два примера кода ниже выполняют одинаковую работу. Оба примера основаны на том, как инструмент Вырезать создает выходную схему.
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"
return
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]
self.params[2].schema.clone = True
return
def updateParameters(self):
# The only property of the clone that changes is that the extent
# of the output is the intersection of the input features
# and the clip features (parameter 1)
self.params[2].schema.extentRule = "Intersection"
return
featureTypeRule
Этот параметр определяет тип объекта выходного класса объектов. Это правило не влияет на выходные растровые данные или таблицы.
Значение | Описание |
---|---|
"AsSpecified" | Тип объекта будет определяться свойством featureType. |
"FirstDependency" | Тип объекта будет таким же, как и первый влияющий параметр. Если первый влияющий параметр содержит несколько значений (список значений), будет использоваться первое значение в этом списке. |
featureType
Если значением featureTypeRule является "AsSpecified", то значение в featureType используется для указания типа объекта выходных данных.
Значение | Описание |
---|---|
"Simple" | Выходные данные будут содержать простые объекты. Тип геометрии объектов указывается с помощью geometryTypeRule. |
"Annotation" | Выходные данные будут содержать объекты аннотаций. |
"Dimension" | Выходные данные будут содержать объекты размеров. |
geometryTypeRule
Этот параметр определяет тип геометрии (например, точка или полигон) выходного класса объектов.
Значение | Описание |
---|---|
"Unknown" | Это установка по умолчанию. Обычно вы должны иметь возможность определить тип геометрии в updateParameters на основе значений других параметров. Вам только нужно установить правило на "Unknown", если у вас нет достаточной информации для определения типа геометрии. |
"FirstDependency" | Тип геометрии будет совпадать с первым влияющим параметром. Если первый влияющий параметр содержит несколько значений (список значений), будет использоваться первое значение в этом списке. |
"Min", "Max" | Проверяются геометрии всех зависимых параметров и устанавливается тип выходной геометрии на минимальный или максимальный найденный тип. "Min" и "Max" пределяются следующим образом:
|
"AsSpecified" | Тип геометрии будет определен значением свойства geometryType. |
geometryType
Установите это значение для типа геометрии ("Point", "Multipoint", "Polyline" или "Polygon") когда geometryTypeRule равно "AsSpecified".
extentRule
Значение | Описание |
---|---|
"AsSpecified" | Выходной экстент будет указан в свойстве extent. |
"FirstDependency" | Выходной экстент будет совпадать с первым влияющим параметром. Если первый влияющий параметр содержит несколько значений (список значений), будет использоваться первое значение в этом списке. |
"Intersection" | Выходным экстентом будет геометрическое пересечение всех влияющих параметров. (Это то, что использует инструмент Вырезать, как показано ниже.) |
"Union" | Выходным экстентом будет геометрическое объединение всех влияющих параметров. |
"Environment" | Выходной экстент будет вычислен на основе настроек Параметров среды экстента. |
Пример
# The extent of the output is the intersection of the input features
# and the clip features (the dependent parameters)
self.params[2].schema.extentRule = "Intersection"
экстент
Установите это для экстента, когда extentRule является "AsSpecified". Можно задать экстент в виде строки, разделенной пробелами, или списка с четырьмя значениями. Последовательность такова: xmin, ymin, xmax, ymax.
Пример
self.params[2].schema.extentRule = "AsSpecified"
self.params[2].schema.extent = "123.32 435.8 987.3 567.9"
# Alternatively use a list, as follows:
# self.params[2].schema.extent = [123.32, 435.8, 987.3, 567.9]
fieldsRule
fieldsRule определяет, какие поля будут у выходного класса объектов или таблицы.
В таблице, приведенной ниже, FID означает Feature ID, но реально связано с полем ObjectID в каждом классе объектов или таблице.
Значение | Описание |
---|---|
"None" | Никакие поля, кроме ObjectID, выводиться не будут. |
"FirstDependency" | Выходные поля будут совпадать с первым влияющим параметром. Если первый влияющий параметр содержит несколько значений (список значений), будет использоваться первое значение в этом списке. |
"FirstDependencyFIDs" | Только ObjectID первого зависимого входного параметра будет записан в выходные данные. |
"All" | Выводятся все поля в списке зависимых параметров. |
"AllNoFIDs" | Выводятся все поля кроме ObjectID. |
"AllFIDsOnly" | Выводятся все поля ObjectID, но другие поля из входных параметров не записываются. |
Ниже приведен пример инструмента Вырезать, использующего fieldsRule из "FirstDependency":
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"
return
additionalFields
Помимо полей, добавленных приложением в fieldsRule, в выходные данные можно добавить дополнительные поля. additionalFields получает список объектов-полей.
cellSizeRule
Это определяет размер ячейки выходных растров или гридов.
Значение | Описание |
---|---|
"AsSpecified" | Размер выходной ячейки указан в свойстве cellSize. |
"FirstDependency" | Размер ячейки вычисляется на основе первого зависимого параметра. Если первым зависимым параметром является растр, используется его размер ячейки. Для других типов зависимых параметров, таких как классы объектов или наборы данных объектов, для вычисления размера ячейки используется экстент данных. Если первый влияющий параметр содержит несколько значений (список значений), будет использоваться первое значение в этом списке. |
"Min", "Max" | "Min" означает, что размер выходной ячейки является наименьшим размером ячейки у зависимых параметров. "Max" означает, что берется наибольший размер ячейки у зависимых параметров. |
"Environment" | Размер выходной ячейки рассчитывается на основе параметра среды Размер ячейки. |
cellSize
Установите для него значение размера ячейки, которое будет использоваться, когда cellSizeRule равно "AsSpecified".
rasterRule
Определяет тип данных (integer или float) в выходных растровых данных.
Значение | Описание |
---|---|
"FirstDependency" | Тип данных (integer или float) будет совпадать с первым влияющим параметром. Если первый влияющий параметр содержит несколько значений (список значений), будет использоваться первое значение в этом списке. |
"Min", "Max" | Целое число считается меньшим, чем число с плавающей точкой. Например, если есть два зависимых параметра, один содержит целочисленные значения, а второй – числа с плавающей точкой, "Min" выдаст выходные значения как целочисленные, а "Max" – как числа с плавающей точкой. |
"Integer" | Выходной растр содержит целочисленные значения. |
"Float" | Выходной растр содержит значения – числа с плавающей точкой. |
rasterFormatRule
Это определяет формат выходного растра: "Grid" или "Img". По умолчанию значением является "Img", это формат ERDAS IMAGINE. "Grid" - это формат Esri.
additionalChildren
Рабочая область является контейнером для наборов данных (объектов, таблиц и растров). Эти наборы данных являются дочерними для рабочей области (вы можете считать рабочую область родителем по отношению к ним). Если инструмент добавляет набор данных к новой или существующей рабочей области, вы можете обновить описание рабочей области, добавив описания дочерних объектов. Например, вы можете использовать инструмент, который получает список классов объектов (многозначный элемент), обновляет их некоторым способом, и затем записывает измененные классы объектов в существующую рабочую область. Если инструмент используется в ModelBuilder, рабочая область является выходным результатом инструмента, и вы можете использовать эту рабочую область в качестве входного параметра для инструмента Выбрать данные. ВыбратьДанные позволяет вам выбрать дочерний набор данных из контейнера и использовать его, как входной параметр для другого инструмента.
Входной параметр для additionalChildren – это одно или более описаний дочерних элементов. Существует две формы описания дочерних элементов:
Форма | Описание |
---|---|
Объект value | Значение класс объектов, таблица, растр, объект-размер или объект аннотации, как результат свойства value. |
Объект списка в форме [type, name, fields, extent, spatial reference] | Список, содержащий добавляемое описание к дочерним элементам Необходимы только первые два элемента списка, type и name. Остальные аргументы являются необязательными. |
При добавлении более одного дочернего элемента предоставьте список описаний дочерних элементов. Если вы добавляете дочерний элемент в форму списка, создайте список списков для additionalChildren.
Форма списка имеет 5 аргументов, как описано в следующей таблице.
Аргумент | Тип | Описание |
---|---|---|
type | Обязательный | Одно из следующих значений: "Point", "Multipoint", "Polyline", "Polygon", "Table", "Raster", "Annotation", "Dimension" |
name | Обязательный | Название набора данных. Это может быть базовое имя набора данных (streets) или полный путь к каталогу (E:\mydata\test.gdb\infrastructure\streets). Если предоставлен полный путь к каталогу, игнорируется все, кроме базового имени ("улицы (streets)"). |
fields | Дополнительный | Список объектов поля. Содержит поля, принадлежащие дочернему элементу, если они известны. |
extent | Дополнительный | Строка или список , содержащие пространственный экстент для дочернего элемента. |
spatial reference | Дополнительный | Объект пространственной привязки. |
Данные аргументы должны быть приведены в указанном порядке. Чтобы пропустить необязательный аргумент, используйте None или '#'.
Ниже приведены примеры задания схемы рабочей области. Эти примеры основаны на инструменте-скрипте, который имеет следующие аргументы:
Индекс параметра | Имя параметра | Свойство |
---|---|---|
0 | Входной класс пространственных объектов | Класс объектов – входной. |
1 | Входная таблица | Таблица – входная. |
2 | Входная рабочая область | Рабочая область – входная (существующая рабочая область, содержащая результаты применения инструмента). |
3 | Извлеченная рабочая область | Рабочая область – Извлеченный выходной результат, полученный из Входной рабочей области. Схема данной рабочей области была изменена, чтобы содержать дополнительные дочерние элементы. |
Инструмент получает входные класс объектов и таблицу, копирует оба элемента в рабочую область, добавляет новое поле в класс объектов и создает класс полигональных объектов в рабочей области. (Фактическая работа инструмента не важна, поскольку она служит только для иллюстрации настройки схемы рабочей области.) Приведенные ниже примеры кода основываются друг на друге, начиная с простого использования additionalChildren.
В initializeParameters выходная рабочая область клонируется из зависимого параметра (parameter 2). Эта зависимость задана в свойствах инструмента, но может быть также установлена в initializeParameters для предотвращения случайного удаления зависимости из свойств инструмента.
class ToolValidator:
def __init__(self):
self.params = arcpy.GetParameterInfo()
def initializeParameters(self):
self.params[3].parameterDependencies = [2] # input workspace
self.params[3].schema.clone = True # Copy all existing contents to output
return
def updateParameters(self):
inFC = self.params[0].value # input feature class
inTable = self.params[1].value # input table
inWS = self.params[2].value # input workspace
if inFC and inTable and inWS:
self.params[3].schema.additionalChildren = [inFC, inTable]
return
Единственные известные свойства для этого нового класса объектов (при проверке) – это имя ("SummaryPolygon") и тип ("polygon").
children = [] # New empty list
children.append(inFC)
children.append(inTable)
children.append(["polygon", "SummaryPolygon"])
self.params[3].schema.additionalChildren = children
# Create a field object with the name "Category" and type "Long".
newField = arcpy.Field()
newField.name = "Category"
newField.type = "Long"
# Describe the input feature class in order to get its list of fields. The 9.3
# version of the geoprocessing object returns fields in a list, unlike previous
# versions, which returned fields in an enumerator.
desc = arcpy.Describe(inFC)
fieldList = desc.fields
# Add the new field to the list
fieldList.append(newField)
# Create a new child based on the input feature class, but with the
# additional field added.
newChild = [desc.shapeType, desc.catalogPath, fieldList,
desc.extent, desc.spatialReference]
# Now create our list of children and add to the schema.
children = []
children.append(newChild)
children.append(inTable)
children.append(["polygon", "SummaryPolygon"])
self.params[3].schema.additionalChildren = children
Чтобы создать поля для класса SummaryPolygon (новый полигональный класс объектов), создайте список объектов полей по образцу, приведенному в примере выше.
В этом примере, первый параметр является объектом со множеством значений из классов объектов. Каждый класс объектов из множественного объекта копируется в извлеченную рабочую область. Новое поле ProjectID добавляется к каждому из скопированных классов объектов.
# 0 - input features (multivalue)
# 1 - input workspace
# 2 - derived workspace
import arcpy
class ToolValidator:
def __init__(self):
self.params = arcpy.GetParameterInfo()
def initializeParameters(self):
self.params[2].parameterDependencies = [1]
self.params[2].schema.clone = True
return
def updateParameters(self):
inVT = self.params[0].value # multivalue ValueTable
inWS = self.params[1].value # WorkSpace
# Add each feature class to the output workspace. In addition,
# add a new field "ProjectID" to each feature class.
if inVT and inWS:
rowCount = inVT.rowCount # Number of rows in the MultiValue table
children = []
newField = arcpy.Field()
newField.name = "ProjectID"
newField.type = "Long"
for row in range(0, rowCount):
value = inVT.getValue(row, 0)
if value:
d = arcpy.Describe(value)
fieldList = d.fields
# Note -- not checking if field already exists
fieldList.append(newField)
# Create new child with additional ProjectID field and
# add child to list of children.
child = [d.shapeType, d.catalogPath, fieldList]
children.append(child)
self.params[2].schema.additionalChildren = children
return
def updateMessages(self):
return
Объект Filter
Объект filter позволяет указать варианты значений параметра, доступные пользователю. Например, можно установить фильтр поля, ограничивающий варианты текстовыми полями. Фильтр выполняет три задания:
- Фильтр только представляет возможного пользователя с доступными вариантами выбора при обзоре данных. Если вы установите фильтр на точечный класс объектов, только точечные классы объектов будут показаны при обзоре данных пользователем. Если вы установите фильтр на текстовые поля, ниспадающий список полей покажет только текстовые поля.
- Если пользователь вводит значение параметра (вместо выбора значения из списка или обзора файлов), значение будет проверено фильтром. Если пользователь вводит некорректное значение (например, числовое поле вместо текстового поля), выводится предупреждение или ошибка.
- Поскольку значения проверяются фильтром с помощью внутренней проверки, вам не придется программировать пользовательскую проверку в классе ToolValidator.
Есть два способа их определения фильтров:
- На вкладке Параметры диалогового окна свойств инструмента, выберите параметр, затем щелкните ячейку рядом с Фильтром и выберите тип фильтра из ниспадающего списка. После того, как вы выбрали тип фильтра, появится диалоговое окно, где вы сможете задать значения для фильтра.
- Вы можете задать значения программно в классе ToolValidator (примеры приведены ниже). Геообработка автоматически создает фильтры для параметров, имеющих тип string, long, double, класс пространственных объектов, файл, поле и рабочая область. Если вы не хотите выбрать фильтр в диалоговом окне свойств инструмента, все равно существует фильтр, который связан с параметром – просто он является пустым. Пустой фильтр равнозначен отсутствию фильтра. Добавляя значения в пустой фильтр, вы активизируйте фильтр, и варианты, из которых может выбирать пользователь, ограничены установками фильтра.
Есть семь видов фильтров, как показано в таблице ниже:
Тип фильтра | Значение |
---|---|
ValueList | Список строковых или числовых значений, которые используются с типами данных String, Long, Double и Boolean. |
Диапазон | Минимальное и максимальное значение, которые используются с типами данных Long и Double. |
FeatureClass | Список допустимых типов классов объектов, определенных значениями "Point", "Multipoint", "Polyline", "Polygon", "MultiPatch", "Sphere", "Annotation" и "Dimension". В фильтре можно задать несколько значений. |
File | Список суффиксов файлов, например, ".txt" или ".xml". |
Поле | Список допустимых типов полей, определенных значениями "Short", "Long", "Single", "Double", "Text", "Date", "OID", "Geometry", "Blob", "Raster", "GUID", "GlobalID" и "XML". В фильтре можно задать несколько значений. |
Рабочая область | Список допустимых типов рабочей области, определенных значениями "FileSystem", "LocalDatabase" и "RemoteDatabase". Может быть задано более одного значения. |
Тип единиц измерения режима передвижения | Список допустимых атрибутов импеданса режима движения: "Time", "Distance" и "Other". |
Свойства
Свойство | Описание |
---|---|
type | Тип фильтра (Список значений (Value List), Диапазон (Range), Класс объектов (Feature Class), Файл (File), Поле (Field), и Рабочая область (Workspace)). Вы можете задать тип фильтра при работе с параметрами Long и Double (см. примечание ниже). Для других типов параметров существует только один корректный тип фильтра, поэтому задание типа для этих параметров игнорируется. Если вы не хотите фильтровать значения, установите свойство списка на пустой список (empty list). |
list | Список значений для фильтра. Если вы не хотите фильтровать значения, установите свойство списка на пустой список (empty list). |
ValueList
ValueList для строковых параметров
Для строкового параметра список может состоять из любого количества строк. Ниже приведен пример настройки списка строковых значений в процедуре initializeParameters. У параметра существуют две возможности: "NEW_FORMAT" и "OLD_FORMAT".
def initializeParameters(self):
# Set the fixed list of "file format type" parameter choices and its
# default value.
self.params[1].filter.list = ["OLD_FORMAT", "NEW_FORMAT"]
self.params[1].value = "OLD_FORMAT"
return
В приведенном выше примере вы можете также задать список значений на вкладке Параметр в диалоговом окне свойств. Если вы установите список значений на что-то другое (например, "OLD" и "NEW") в свойствах инструмента, эти значения будут заменены на "OLD_FORMAT" и "NEW_FORMAT" при вызове initializeParameters. То же верно для значения по умолчанию – оно может быть установлено в диалоговом окне Свойств инструмента, и затем переустановлено в ToolValidator.
Примечание:
Список значений, которые вы задаете в ToolValidator, заменяет значения, установленные в диалоговом окне Свойства инструмента. Это позволяет вам обновлять значения, основанные на других параметрах.
Продолжая работу с данным примером, следующий код отображает процедуру updateParameters, изменяющую список значений в другом параметре в зависимости от того, выбрал ли пользователь вариант "OLD_FORMAT" или "NEW_FORMAT":
def updateParameters(self):
# Update the value list filter of the "feature type in file" parameter
# depending on the "file format type" parameter.
if self.params[1].value.upper() == "OLD_FORMAT":
self.params[2].filter.list = ["POINT", "LINE", "POLYGON"]
elif self.params[1].value.upper() == "NEW_FORMAT":
self.params[2].filter.list = ["POINT", "LINE", "POLYGON",
"POINT_WITH_ANNO",
"LINE_WITH_ANNO",
"POLYGON_WITH_ANNO"]
# Provide default value for "feature type in file" parameter.
if not self.params[2].altered:
self.params[2].value = "POINT"
ValueList для параметров с типами данных Long и Double
Параметр Long или Double может иметь список числовых значений. Пользователь может или выбрать значение из списка, или ввести значение, также из списка.
# Set filter for a Long parameter
self.params[7].filter.list = [10, 20, 30, 40, 50]
# Set filter for a Double parameter
self.params[8].filter.list = [10.0, 12.5, 15.0]
ValueList для логических параметров
Для Булева параметра существует два значения: истинный (true) и ложный (false). Истинное значение (true) всегда идет в списке первым.
def initializeParameters(self):
# Set the Boolean choice for including or excluding angles.
self.params[6].filter.list = ["ANGLE", "NO_ANGLE"]
# Set the default value to false (no angle).
self.params[6].value = "NO_ANGLE"
return
def updateParameters(self):
# Enable angle format parameter if user wants angles.
if self.params[6].value.upper() == "ANGLE":
self.params[7].enabled = True
Диапазон
Для параметров с типом данных Long и Double может быть установлен фильтр диапазона. У фильтров диапазона два значения: минимум и максимум. Первым в списке идет минимальное значение. Диапазон является инклюзивным, то есть в него входят минимальное и максимальное значения.
def initializeParameters(self):
# Utility values must be between -10 and 10.
self.params[7].filter.list = [-10, 10]
Установка типа фильтра для параметров long и double
Для параметров Long и Double, фильтром по умолчанию является ValueList. Если вы хотите использовать Фильтр диапазона, установите тип фильтра в initializeParameters, как показано ниже:
def initializeParameters(self):
# Set the 'score' value parameters to a range filter
self.params[7].filter.type = "Range"
self.params[7].filter.list = [-10, 10]
Вы можете задать тип фильтра только для параметров Long и Double.
FeatureClass
Пример, приведенный ниже, показывает установку типа объекта для одного из входных параметров на основе типа объекта другого входного параметра.
def updateParameters(self):
# Set the input feature type of the second parameter based
# on the feature type of the first parameter.
if self.params[0].valueAsText:
desc = arcpy.Describe(self.params[0])
feature_type = desc.shapeType.lower()
if feature_type == "polygon":
self.params[1].filter.list = ["point", "multipoint"]
elif feature_type == "polyline":
self.params[1].filter.list = ["polygon"]
elif feature_type in ["point", "multipoint"]:
self.params[1].filter.list = ["polyline"]
else:
self.params[1].filter.list = []
return
File
Фильтр файлов содержит список допустимых суффиксов файлов, таких как .txt (простой текстовый файл) и .csv (значения, разделенные запятыми). Можно использовать любое расширение. Совсем не обязательно, чтобы приложение ArcGIS распознавало расширение. Расширение может иметь любую длину и не должно содержать точек. На примере, приведенном ниже, показано задание фильтра для входного параметра Файл.
def initializeParameters(self):
# Set the input file type to our recognized options file suffixes.
self.params[0].filter.list = ["opt56", "opt57", "globalopt"]
return
Поле
Фильтр поля определяет допустимые типы полей. Значения могут быть "Short", "Long", "Float", "Single", "Double", "Text", "Date", "OID", "Geometry", "Blob", "Raster", "GUID", "GlobalID" и "XML".
Отображаемое имя и внутреннее имя
Четыре типа поля, которые имеют внутреннее имя, показаны в таблице ниже:
Отображаемое имя | Внутреннее имя |
---|---|
Short | SmallInteger |
Long | Integer |
Float | Single |
Текст | String |
При определении фильтра поля, вы можете использовать как отображаемое, так и внутреннее имя; то есть следующие две строки кода эквивалентны:
self.params[1].filter.list = ["Short", "Long", "Float", "Text"]
self.params[1].filter.list = ["SmallInteger", "Integer", "Single", "String"]
Если вы предоставляете отображаемое имя, например "short", оно конвертируется и добавляется в фильтр как "SmallInteger" Скорее всего, вы не будете обращаться к значениям в фильтре поля, но если вам придется это делать, учитывайте, что там хранится внутреннее имя. Фрагмент кода, приведенный ниже, показывает, как это вычислить:
self.params[1].filter.list = ["Short", "Long"]
if self.params[1].filter.list[0].lower() == "SmallInteger":
# do something
Задание значения поля по умолчанию
Вы можете указать значение по умолчанию для параметра поля, создав цикл с использованием полей входной таблицы, и выбрав первое поле, которое удовлетворяет фильтру.
def initializeParameters(self):
self.params[1].filter.list = ["Short", "Long", "Float", "Double"]
return
def updateParameters(self):
if self.params[0].valueAsText and not self.params[1].altered:
self.params[1].value = ""
desc = arcpy.Describe(self.params[0])
fields = desc.fields
# Set default to the first field that matches your filter.
for field in fields:
fType = field.type.lower()
if fType in ["SmallInteger", "Integer", "Single", "Double"]:
self.params[1].value = field.name
break
return
Внимание:
Не используйте функцию ListFields в ToolValidator. Вместо этого, используйте функцию Describe, как проиллюстрировано выше.
Рабочая область
В фильтре рабочей области указываются типы допустимых рабочих областей на входе. Существует три значения:
Фильтр рабочей области | Описание |
---|---|
FileSystem | Системная папка, используемая для хранения шейп-файлов и сеток |
LocalDatabase | Файловая база геоданных |
RemoteDatabase | Подключение многопользовательской базы геоданных |