У всех работающих инструментов есть входные и выходные параметры. Без входных параметров инструмент будет выполнять одну и ту же обработку при каждом запуске. При изменении значения входного параметра инструмент будет выдавать разные результаты. Выходные параметры позволяют инструменту вернуть результат. Сервис геообработки, который обеспечивает работу другого сервиса геообработки, имеет четко определенные правила для входных и выходных параметров. Эти правила приведены ниже, они гарантируют, что инструмент подходит для работы в веб и может быть опубликован на клиентах, которые будут с ним взаимодействовать.
Входные параметры
При создании инструмента геообработки может использоваться более 100 типов данных уникальных параметров, которые могут служить входными данными. Выбор определенного типа данных помогает предоставить инструменту ожидаемые входные данные. Многие типы данных довольно специфические и не поддерживаются сервисом геообработки. При создании инструмента, который впоследствии будет опубликован в качестве сервиса геообработки, лучше всего создавать его с учетом поддерживаемых типов данных. Инструмент, который вы создаете и распространяете среди коллег, может быть настроен несколько иначе, чем инструмент, который в конечном итоге будет опубликован как сервис геообработки.
Поддерживаемые типы входных данных в ArcGIS Pro могут быть любыми из следующих типов данных в левом столбце приведенной ниже таблицы. После публикации они будут преобразованы в соответствующие типы данных в ArcGIS Enterprise.
Тип данных в ArcGIS Pro | Тип данных в ArcGIS Enterprise |
---|---|
Набор объектов, Векторный слой | |
Набор растровых данных, Растровый слой | |
Набор записей, Представление таблицы | |
Файл | |
Логическое значение (Boolean), Двойное (Double), Длинное (Long), Строка (String) (текст) | |
Дата | |
Линейные единицы измерения | |
Поле | |
Таблица значений |
Поле
Поле - это столбец в таблице, в котором хранятся значения отдельного атрибута.
Создание
Для инструментов, имеющих входной параметр поля, следует убедиться, что этот параметр поля имеет зависимость от параметра, такого как векторный слой или таблица.
Если вы используете версии от ArcGIS Pro 2.3 до ArcGIS Pro 2.9, в качестве зависимости поддерживаются только набор объектов и входной векторный слой. Если вы ведете публикацию из ArcGIS Pro 3.0 или более поздних версий в ArcGIS Enterprise с версии 11.0 или более поздних, тип данных поля может зависеть от всех поддерживаемых объектов и типов таблиц входных данных.
Запуск инструмента
Если вы запускаете инструмент до публикации между версиями ArcGIS Pro 2.3 и ArcGIS Pro 2.9, для векторных слоёв, от которых зависят эти параметры полей, выберите класс объектов с диска. Не используйте векторный слой в качестве входных данных.
В версии ArcGIS Pro 3.0 или более поздней и при публикации в ArcGIS Enterprise версии 11.0 или более поздней, нет никаких ограничений на то, как вы выбираете входные данные. Вы можете использовать слой объектов, класс объектов на диске, таблицу или табличное представление для слоев, от которых зависит параметр поля.
Публикация
При настройке свойств инструмента убедитесь, что Режим входных данных и для входного объекта, и для поля(ей) задан как Пользовательское значение.
Использование
При использовании сервиса геообработки в ArcGIS Pro все применимые поля в ниспадающем списке будут автоматически заполнены после того, как вы выберете входные данные.
Примечание:
Тип данных поля не поддерживается в приложениях, созданных в ArcGIS Web AppBuilder или Map Viewer Classic в Portal for ArcGIS.
Таблица значений
Таблица значений - это гибкий объект типа таблицы, состоящий из строк и столбцов и содержащий разные значения. Чтобы использовать тип данных поля Таблица значений, необходимо установить ArcGIS Pro 3.0 или более позднюю и ArcGIS Enterprise версии 10.7 или более позднюю. Чтобы узнать больше о таблице значений, посмотрите раздел Таблица значений. Многозначность не поддерживается таблицей значений.
Создание
Хотя имена столбцов параметра таблицы значений могут быть пустыми или дублироваться, при разработке параметров инструмента рекомендуется использовать уникальные и непустые имена столбцов. Уникальные и непустые имена столбцов позволяют пользователям вашего веб-инструмента различать разные столбцы при использовании веб-инструмента, особенно при наличии нескольких столбцов с одинаковыми типами данных.
Публикация
Вы можете опубликовать сервис геообработки с входным или выходным параметром таблицы значений в Python. Если столбец в параметре таблицы значений имеет фильтр, процесс публикации будет включать этот фильтр.
Подробные сведения о публикации сервисов геообработки в скрипте Python
Использование
Вы можете применять сервис геообработки с входным или выходным параметром таблицы значений с помощью ArcGIS Pro 3.0 или в Python. Тип данных Таблица значений не поддерживается в Web AppBuilder или Map Viewer Classic.
Неподдерживаемые входные параметры
Если параметр, который вы используете при создании инструмента, не перечислен выше, это значит, что он не поддерживается сервисом геообработки. При публикации сервиса геообработки неподдерживаемый параметр будет либо жестко закодирован в сервисе, либо преобразован в поддерживаемый тип. Зная это, вы можете создать инструмент и разрешить своим пользователям взаимодействовать с ним так, как вы этого ожидаете. Как неподдерживаемый тип параметра будет преобразован, зависит от самого параметра. При публикации сервиса геообработки вы можете изучить преобразование параметра, используя сведения в разделе Настройка свойств инструмента в разделе Содержание. В примерах ниже приведены популярные параметры и варианты их изменения для работы в сервисе геообработки.
Например, параметр класса пространственных объектов поддерживает как шейп-файлы, так и классы объектов на диске. Однако ваш инструмент может использовать параметр векторного слоя или набора объектов. Параметр векторного слоя поддерживает выборку из списка слоев. Этот список слоев будет тем же самым, что и слои вашей карты на момент публикации. Либо вы можете использовать параметр набор объектов. Этот параметр позволяет интерактивный ввод объектов. Веб-приложение, использующее сервис геообработки с входным набором объектов будет позволять пользователю создавать объекты в сервисе, с которым он взаимодействует. Эти замечания также применимы к таблицам и наборам записей. Все эти методы позволяют вводить входные данные объектов; однако при публикации они создают очень разные сервисы. Ваш рабочий процесс подскажет, какие типы данных больше всего подходят.
Два широко используемых типа параметра, которые становятся жестко закодированными при публикации - это рабочая область и типы папок. Для рабочего процесса может понадобиться файл подключения .sde или папка, после чего он выполнит операцию для элементов данной папки. Рабочую область нельзя перенести с клиента на сервис геообработки. Вместо этого она жестко кодируется внутри публикуемого сервиса. Эта жестко закодированная ссылка указывает на местоположение, содержащее указанные элементы, либо в виде ссылок либо в виде копий, в зависимости от настроек хранилища данных. Опубликованный сервис будет продолжать использовать эту рабочую область и ее содержимое так же, как это делал инструмент до публикации. Единственное различие заключается в том, что пользователь сервиса эту рабочую область поменять не может.
Выходные параметры
В обычном рабочем процессе у вашего сервиса геообработки будет как минимум один выходной параметр. Именно через выходной параметр сервис геообработки возвращает результат клиенту. Без этого параметра сервис ничего не будет возвращать, и может показаться, что его запуск не удался. Так же, как и в случае с входными параметрами, сервисы геообработки поддерживают только определенный перечень типов данных для выходных параметров.
Подсказка:
Если создаваемому вами инструменту не нужен выходной параметр, поскольку целью инструмента является выполнить обновление или действие в определенное время, вам может не понадобиться сервис геообработки. В этом случае рекомендуется создавать запланированные задачи.Поддерживаемые типы выходных данных могут иметь тип параметра производный или требуемый и могут быть любыми из следующих типов данных в левом столбце приведенной ниже таблицы в ArcGIS Pro. После публикации они будут соответствовать типам данных в правом столбце в ArcGIS Enterprise.
Тип данных в ArcGIS Pro | Тип данных в ArcGIS Enterprise |
---|---|
Класс пространственных объектов | |
Набор растровых данных | |
Таблица | |
Файл | |
Логическое значение (Boolean), Двойное (Double), Длинное (Long), Строка (String) (текст) | |
Дата | |
Линейные единицы измерения | |
Поле | |
Таблица значений |
Жестко закодированные выходные данные
Возможно наиболее подходящим вариантом будет тот, при котором все выходные результаты будут статичными для пользователей сервиса. Когда сервис геообработки запускается в настольном или веб-приложении, он не требует указать какое-либо значение в качестве выходного параметра. Это может удивить вас в первый раз, когда вы попытаетесь запустить сервис, поскольку вам не будет предоставлена возможность задать выходное имя для класса объектов. При публикации сервиса геообработки выходные данные обрабатываются процессом, публикующим сервис геообработки. Имя выходных данных при запуске инструмента в ArcGIS Pro используется для результатов работы сервиса. Сервис определяет запись результатов в папку in_memoryили временную рабочую область (scratchGDB или scratchFolder) и возвращает результат на клиент после успешного выполнения обработки.
Неподдерживаемые выходные параметры
Некоторые типы параметров не поддерживается в сервисе геообработки и не могут быть возвращены на клиент. Примерами являются рабочие пространства и сложные типы, такие как наборы сетевых данных и геометрические сети. Рабочая область, например, может быть папкой, набором данных объектов или файлом подключения .sde. Сервис не может вернуть в результате своей работы папку или хранилище с элементами. Если в рабочем процессе требуется отправить обратно множество элементов или сложные элементы, состоящие из нескольких компонентов, вам может потребоваться упаковать эти элементы в архив и вернуть .zip файл. Или, если позволяет рабочая область, вы сможете использовать инструмент Копировать объекты и вернуть результат в виде упрощенного класса объектов.