标注 | 说明 | 数据类型 |
输入图层 | 将进行打包的图层。 | Layer; Table View |
输出文件 | 将创建的输出包文件 (.lpkx) 的位置和名称。 | File |
将数据转换为文件地理数据库 (可选) | 指定输入图层是转换为文件地理数据库还是保留原始格式。
| Boolean |
包括企业级地理数据库数据,而不是引用该数据 (可选) | 指定是将输入企业级地理数据库图层转换为文件地理数据库,还是保留其原始格式。
| Boolean |
范围 (可选) | 指定用于选择或裁剪要素的范围。
| Extent |
仅将范围应用到企业级地理数据库图层 (可选) | 指定是将指定范围应用到所有图层,还是仅应用到企业级地理数据库图层。
| Boolean |
仅方案 (可选) | 指定是否仅合并或打包输入图层的方案。
| Boolean |
包版本 (可选) | 指定将在结果包中创建的地理数据库版本。 指定版本可实现与较早版本的 ArcGIS 共享包,并可支持向后兼容。 注:保存为较早版本的包可能会丢失仅适用于较新版本的属性。
| String |
附加文件 (可选) | 将添加到包中的附加文件。 诸如 .doc、.txt、.pdf 等附加文件可用于提供有关打包内容和目的的详细信息。 | File |
摘要 (可选) | 将添加到包属性中的摘要信息。 | String |
标签 (可选) | 将添加到包属性中的标签信息。 可以添加多个标签,标签之间用逗号或分号进行分隔。 | String |
仅保留与范围内要素相关的行 (可选) | 指定是否将指定的范围应用至相关数据源。
| Boolean |
保留移动地理数据库 (可选) | 指定输入移动地理数据库数据是保留在输出中还是写入文件地理数据库格式。 如果输入数据是移动地理数据库网络数据集,则输出将为移动地理数据库。 当输入数据为移动地理数据库时,此参数将覆盖将数据转换为文件地理数据库参数。
| Boolean |
排除网络数据集 (可选) | 对于网络分析图层,指定是否还将对网络数据集进行打包。
| Boolean |
摘要
对一个或多个图层以及所有引用的数据源进行打包以创建单个的压缩 .lpkx 文件。
使用情况
此工具遇到不支持的图层类型时会发出警告。 不受支持的图层类型将不会写出到输出。
所有输入图层必须包含工具的描述,才能运行。 要添加描述,请右键单击该图层并单击属性,然后提供描述信息。
选中将数据转换为文件地理数据库参数时,将出现以下情况:
- 每个唯一数据会具有一个在合并文件夹或包中创建的文件地理数据库。
- 压缩栅格和矢量格式会转换为一个文件地理数据库,并且原来的数据压缩将会丢失。
- 不会合并企业级地理数据库数据。 要将企业级地理数据库数据转换为文件地理数据库,请选中包括企业级地理数据库数据,而不是仅引用该数据参数。
未选中将数据转换为文件地理数据库参数时,将出现以下情况:
- 将保留输入图层的数据源格式(如果可能)。
- ADRG、CADRG/ECRG、CIB 和 RPF 栅格格式将转换为文件地理数据库栅格。 ArcGIS 本身不能写出这些格式。 出于效率方面的考虑,这些格式将转换为文件地理数据库栅格。
- 在输出文件夹结构中,文件地理数据库将合并到一个特定于版本的文件夹中,并且所有其他格式都将合并到 commonData 文件夹中。
- 即使在范围参数中指定了范围,也不会裁剪压缩栅格和矢量格式。
对于包含连接或参与关系类的图层,所有连接或相关的数据源都将合并到输出文件夹。 默认情况下,连接或关联数据源将全部合并,或根据为范围参数指定的范围,由选择相关行参数值决定。
对于要素图层,范围参数用来选择将要合并的要素。 对于栅格图层,范围参数用来裁剪栅格数据集。
有些数据集会引用其他数据集。 例如,您可能拥有一个引用了四个要素类的拓扑数据集。 引用其他数据集的数据集示例还包括几何网络、网络和定位器。 基于这些数据集类型合并或打包图层时,参与数据集也将被合并或打包。
如果选中仅方案参数,则将仅合并或打包输入数据源的方案。 方案是由字段和表定义、坐标系属性、符号系统、定义查询等组成的要素类或表的结构或设计。 将不会合并或打包所有数据和记录。
不支持“仅方案”的数据源不能进行合并和打包。 如果选中仅方案参数,并且此工具遇到“仅方案”不支持的图层,则会显示一条警告消息,并会跳过该图层。 如果仅方案不支持指定的唯一图层,则该工具将失败。
要对图层包(.lpkx 文件)进行解包,请在目录窗口中浏览至包含该图层包的文件夹,右键单击该包,然后单击添加至当前地图。 或者可使用提取包工具并指定一个输出文件夹。
默认情况下,添加至当前地图可将包提取到 C:\Users\<username>\Documents\ArcGIS\Packages 下的用户配置文件中。 要更改提取位置,请在共享和下载选项对话框上更新其他包和文件下的路径。
注:
在 ArcGIS AllSource 中创建的图层包无法向后与 ArcGIS 10 和 ArcGIS 9.3.1 兼容。 在 ArcGIS AllSource 中创建的包只能在 ArcGIS AllSource 中使用。
参数
arcpy.management.PackageLayer(in_layer, output_file, {convert_data}, {convert_arcsde_data}, {extent}, {apply_extent_to_arcsde}, {schema_only}, {version}, {additional_files}, {summary}, {tags}, {select_related_rows}, {preserve_sqlite}, {exclude_network_dataset})
名称 | 说明 | 数据类型 |
in_layer [in_layer,...] | 将进行打包的图层。 | Layer; Table View |
output_file | 将创建的输出包文件 (.lpkx) 的位置和名称。 | File |
convert_data (可选) | 指定输入图层是转换为文件地理数据库还是保留原始格式。
| Boolean |
convert_arcsde_data (可选) | 指定是将输入企业级地理数据库图层转换为文件地理数据库,还是保留其原始格式。
| Boolean |
extent (可选) | 指定用于选择或裁剪要素的范围。
| Extent |
apply_extent_to_arcsde (可选) | 指定是将指定范围应用到所有图层,还是仅应用到企业级地理数据库图层。
| Boolean |
schema_only (可选) | 指定是否仅合并或打包输入图层的方案。
| Boolean |
version [version,...] (可选) | 指定将在结果包中创建的地理数据库版本。 指定版本可实现与较早版本的 ArcGIS 共享包,并可支持向后兼容。 注:保存为较早版本的包可能会丢失仅适用于较新版本的属性。
| String |
additional_files [additional_files,...] (可选) | 将添加到包中的附加文件。 诸如 .doc、.txt、.pdf 等附加文件可用于提供有关打包内容和目的的详细信息。 | File |
summary (可选) | 将添加到包属性中的摘要信息。 | String |
tags (可选) | 将添加到包属性中的标签信息。 可以添加多个标签,标签之间用逗号或分号进行分隔。 | String |
select_related_rows (可选) | 指定是否将指定的范围应用至相关数据源。
| Boolean |
preserve_sqlite (可选) | 指定移动地理数据库数据是保留在输出中还是写入文件地理数据库格式。 如果输入数据是移动地理数据库网络数据集,则输出将为移动地理数据库。 当输入数据为移动地理数据库时,此参数将覆盖 convert_data 参数。
| Boolean |
exclude_network_dataset (可选) | 对于网络分析图层,指定是否还将对网络数据集进行打包。
| Boolean |
代码示例
以下 Python 脚本演示了如何在 Python 窗口中使用 PackageLayer 函数。
# In this code, it is assumed that the current project has a map open with a layer named "Streets".
import arcpy
outputFile = "c:/packages/streetsLayer.lpkx"
arcpy.management.PackageLayer("Streets", outputFile, "PRESERVE",
"CONVERT_ARCSDE", "#", "ALL", "ALL", "CURRENT",
"C:/readme.docx", "Summary of package",
"parcel,montgomery")
将给定项目的第一个地图中的所有要素图层打包到它们自己的单独图层包文件中。
# Import system modules
import os
import arcpy
prj = arcpy.mp.ArcGISProject(r"\\fileServe\projects\Timbuktu\Timbuktu.aprx")
maps = prj.listMaps()[0]
lyrs = maps.listLayers()
for lyr in lyrs:
if lyr.isFeatureLayer:
arcpy.management.PackageLayer(lyr, os.path.join("c:/temp", lyr.name + ".lpkx"))