Упаковать слой (Package Layer) (Управление данными (Data Management))
Резюме
Упаковывает один или более слой и все связанные источники данных для создания единого сжатого файла .lpk.
Использование
Возникает предупреждение, если этому инструменту встречается неподдерживаемый тип слоя (Schematics или слой инструмента). Неподдерживаемый слой не будет записан в выходные данные.
Для запуска инструмента все входные слои должны содержать описание. Чтобы добавить описание, щелкните правой кнопкой слой, нажмите Свойства (Properties), и введите описание.
При объединении или упаковке слоев результирующие слои будут переименованы в соответствии с принятыми условными обозначениями <integer><layername>.lyr (например, 0000roads.lyr). Такое переименование требуется в целях обеспечения уникальных имен слоев в объединенной папке для всех слоев, ссылающихся на уникальные источники данных и содержащих одинаковые имена слоя в ArcMap.
Пакеты слоя поддерживают обратную совместимость с ArcGIS 10 и ArcGIS 9.3.1. Для создания пакета слоя, совместимого с предыдущими версиями, используйте параметр Версия пакета (Package Version). Важно отметить, что за счет обновления и расширения функций для некоторых элементов баз геоданных, но не все пакеты слоев, будут обратно совместимыми.
Если установлен флажок Конвертировать данные в файловую базу геоданных (Convert Data to File Geodatabase)
- Каждый уникальный источник данных будет иметь уникальную файловую базу геоданных, созданную в объединенной папке или пакете.
- Сжатые растровые и векторные форматы будут конвертированы в файловую базу геоданных, и сжатие будет утеряно.
- Объединение для многопользовательской базы геоданных не выполняется. В целях преобразования данных многопользовательских баз данных необходимо установить флажок Вместо привязки к данным включить данные корпоративной базы геоданных (Include Enterprise geodatabase data instead of referencing the data).
Если флажок Конвертировать данные в файловую базу геоданных (Convert Data to File Geodatabase) снят.
- Формат источника данных входных слоев будет сохранен. Исключением являются такие форматы как данные персональных баз геоданных (.mdb), данные VPF и таблицы на основе электронных таблиц Excel или подключений OLEDB. Эти форматы не поддерживают среды 64х и, таким образом, они всегда преобразовываются в файловые базы геоданных.
- Растровые форматы ADRG, CADRG/ECRG и RPF преобразовываются в формат файловой базы геоданных. ArcGIS не может напрямую писать из этих форматов. Они всегда будут конвертироваться в растры файловой базы геоданных для повышения эффективности.
- В структуре выходной папки файловые базы геоданных будут объединены в специфичную для версий папку, а все другие форматы будут объединены в папку commonData.
- Сжатые растровые и векторные форматы не будут вырезаться, даже если экстент задан в параметре Экстент (Extent).
-
Для слоев, которые содержат соединение или участвуют в классах отношений, все соединенные или связанные источники данных будут объединены в выходную папку.
-
Для векторных слоев, параметр Экстент (Extent) используется для выбора пространственных объектов, которые будут объединены. Для растровых слоев, параметр Экстент (Extent) используется для вырезания наборов растровых данных.
-
Некоторые наборы данных ссылаются на другие наборы данных. Например, у вас может быть набор данных топологи, который ссылается на четыре класса пространственных объектов. Другие примеры наборов данных, которые ссылаются на другие наборы данных, включают Геометрические сети (Geometric Networks), Сети (Networks) и Локаторы (Locators). При размещении или пакетировании слоя на основе этих типов наборов данных, участвующие наборы данных также будут размещены или пакетированы.
Если установлен соответствующий флажок, параметр Только схема (Schema Only) будет объединять или запаковывать схему источников входных данных. Схема — это структура или дизайн класса пространственных объектов или таблицы, состоящей из полей и определений таблицы, свойств системы координат, символов, определяющих запросов и т. д. Объединение или упаковка данных или записей не выполняется.
Источники данных, которые не поддерживают только схему, не будут объединены или упакованы. Если отмечен параметр Только схема (Schema Only) и инструменту встречается слой, который поддерживается не только схемой, отображается предупреждающее сообщение и этот слой будет пропущен. Если единственный указанный слой не поддерживается только для схемы, инструмент не будет выполнен.
В результате объединения или упаковки Покрытия (Coverage) или слоев VPF, они будут скопированы в объединенную папку или пакет.
-
Чтобы распаковать пакет слоев, либо перетащите файл .lpk в ArcMap, либо щелкните правой кнопкой файл .lpk и выберите Распаковать (Unpack). Или же вы можете воспользоваться инструментом Распаковать (Extract Package) и задать выходную папку.
По умолчанию инструмент Распаковать (Unpack) всегда извлекает пакет в профиль пользователя в папке:
- XP—C:\Documents and Settings\<username>\My Documents\ArcGIS\Packages
- Vista and Windows 7—C:\Users\<username>\Documents\ArcGIS\Packages
Чтобы изменить папку, в которую по умолчанию распаковывается содержимое пакетов, выберите пункт Параметры ArcMap (ArcMap Options) в меню Настройка (Customize). На вкладке Общий доступ (Sharing) найдите раздел Упаковка (Packaging) и выберите пункт Использовать определенное пользователем местоположение (Use user specified location), после чего перейдите в новую папку.
Синтаксис
Параметр | Объяснение | Тип данных |
in_layer [in_layer,...] |
Слои для упаковки. | Layer |
output_file |
Местоположение и имя создаваемого выходного файла пакета (.lpk). | File |
convert_data (дополнительно) |
Устанавливает, будут ли входные слои конвертированы в файловую базу геоданных или сохранят свои исходные форматы.
| Boolean |
convert_arcsde_data (дополнительно) |
Устанавливает, будут ли входные слои многопользовательской базы геоданных преобразованы в файловую базу геоданных или сохранят свои исходные форматы.
| Boolean |
extent (дополнительно) |
Задайте экстент, введя вручную координаты в параметре экстента, используя формат X-Min Y-Min X-Max Y-Max. Для использования экстента конкретного слоя укажите имя слоя.
| Extent |
apply_extent_to_arcsde (дополнительно) |
Определяет, будет ли указанный экстент ко всем слоям или только к многопользовательские слои базы геоданных.
| Boolean |
schema_only (дополнительно) |
Указывает, будет ли только схема входных слоев собрана или упакована.
| Boolean |
version [version,...] (дополнительно) |
Указывает версию базы геоданных, которая будет создана в результирующем пакете. Указание версии позволяет осуществлять общий доступ к пакетам из предыдущих версий и поддерживает обратную совместимость.
| String |
additional_files (дополнительно) |
Добавляет дополнительные файлы в пакет. Дополнительные файлы, например .doc, .txt, .pdf и пр., используются для предоставления дополнительной информации о содержимом и назначении пакета. | File |
summary (дополнительно) |
Добавление краткого описания в свойства пакета. | String |
tags (дополнительно) |
Добавление информации о тегах в свойства пакета. Можно добавить несколько тегов с разделением запятой или точкой с запятой. | String |
Пример кода
Следующий скрипт Python демонстрирует, как использовать инструмент PackageLayer из окна Python.
import arcpy
arcpy.env.workspace = "C:/arcgis/ArcTutor/BuildingaGeodatabase/Layers"
arcpy.PackageLayer_management('Parcels.lyr', 'Parcel.lpk', "PRESERVE", "CONVERT_ARCSDE", "#", "ALL", "AlL", "CURRENT", "C:/readme.docx","Summary of package","parcel,montgomery")
Находит и создает отдельные пакеты слоев для всех файлов слоев, которые находятся в указанной папке.
# Name: PackageLayerEx1.py
# Description: Find all the layer files that reside in a specified folder and create a layer package for each layer file.
# import system modules
import os
import arcpy
from arcpy import env
# Set environment settings
env.overwriteOutput = True
env.workspace = "C:/arcgis/ArcTutor/BuildingaGeodatabase/Layers"
# Loop through the workspace, find all the layer files (.lyr) and create a layer package using the same name as the original layer file.
for lyr in arcpy.ListFiles("*.lyr"):
print "Packaging " + lyr
arcpy.PackageLayer_management(lyr, os.path.splitext(lyr)[0] + '.lpk', "PRESERVE", "CONVERT_ARCSDE", "#", "ALL", "ALL", "CURRENT", "#","Summary of package","tag1, tag2")
Находит и создает один пакет слоев для всех файлов слоев, которые находятся в указанной папке.
# Name: PackageLayerEx2.py
# Description: Find all the layer files that reside in a specified folder and create a single layer package that will contain all layers found.
# import system modules
import os
import arcpy
from arcpy import env
# Set environment settings
env.overwriteOutput = True
env.workspace = "C:/arcgis/ArcTutor/BuildingaGeodatabase/Layers"
# Find all the layer files (.lyr) in a workspace and create a single layer package.
lyrs = arcpy.ListFiles("*.lyr")
arcpy.PackageLayer_management(lyrs, 'all_layers.lpk', "PRESERVE", "CONVERT_ARCSDE", "#", "ALL", "ALL", "CURRENT", "#","Summary of package","tag1,tag2")