打包工程 (数据管理)

摘要

将引用地图和数据的工程文件 (.aprx) 合并并打包到已打包的工程文件 (.ppkx) 中。

使用情况

  • 将工程的所有元素合并到工程包 (.ppkx) 中,这些元素包括地图和 3D 视图、位于地图中的数据和图层、工具箱、地理处理历史项目、样式、布局以及文件夹或连接(服务器、工作流等)(如果适用)。

  • 默认情况下,创建的工程包供内部使用。 在组织外共享参数可用于控制是创建供内部使用(组织网络内)的包,还是创建供外部使用的包。 如果选中在组织外共享,则通过 UNC 路径参考的企业级地理数据库图层和数据将包括在工程包内。

    注:

    必须通过企业级地理数据库或 UNC 文件路径引用数据源才能创建保持引用数据的内部包。 将始终合并和打包本地数据路径。 如果要在环境外部共享内部包(其中的数据仅供参考之用)或将其共享给不具有企业级地理数据库或 UNC 数据共享访问权限的同事,则在创建该包时将打开损坏的链接。

  • 可使用打包为模板参数创建模板。 使用工程模板(.aptx 文件),可通过定义图层、地图和数据以及所需的连接来创建新工程。

    了解有关创建工程模板的详细信息

  • 在执行合并进程之前,将使用针对 Pro 分析工具工具分析属于工程组成部分的工具箱。 识别出的错误将停止合并进程。 您必须修复这些错误,或从工程中移除工具。 无论数据是否属于工程中的地图,都将合并工具所需的输入数据。 通过取消选中包括工具箱参数可以将工具箱从输出工程包中排除。

  • 与工程工具箱类似,地理处理历史(来自运行地理处理工具的结果信息)将包含在包中。 处理历史项目所需的数据将包括在输出包中,而无论其是否存在于地图或场景中。 任何无效(在处理过程中失败)或者无法找到数据的历史项目都将导致打包过程停止。 您必须移除或修复有问题的历史项目。 通过取消选中包括历史项目参数可以将历史项目从输出工程包中排除。

  • 连接(例如文件夹、服务器、数据库以及工作流)将仅包括在内部包中。 如果创建包的目的是要在组织外共享,则将移除这些项目。

  • 如果项目(例如附件、样式和任务)为 UNC 路径中的工程的一部分,则将对内部包引用项目。 在所有其他情况下,都将对这些项目进行复制和打包。

  • 对于要素图层,使用范围参数选择将要合并的要素。 对于栅格图层,使用范围参数裁剪栅格数据集。

  • 记录地图和数据或提供详细信息的文件可包括在包中。 使用附加文件参数引用图像、PDF、Word 文档和 .zip 文件,可将其包括在包中。

  • 警告:

    只能通过 .ppkx 创建和打开工程包 (ArcGIS Pro 文件)。

参数

标注说明数据类型
输入工程

要打包的工程(.aprx 文件)。

File
输出文件

输出工程包(.ppkx 文件)。

File
在组织外共享
(可选)

指定是针对内部环境合并工程,还是移动所有数据元素以便在外部共享工程。

注:

如果工程通过本地路径(例如 c:\gisdata\landrecords.gdb\)引用数据和地图,则将对这些数据和地图进行合并和打包(不考虑该参数设置)。

  • 未选中 - 企业数据源(例如企业级地理数据库和 UNC 路径中的数据)将不会复制到本地文件夹。 这是默认设置。
  • 选中 - 将复制和保留数据格式(如有可能)。
Boolean
打包为模板
(可选)

指定将创建工程模板还是工程包。 工程模板可以包含地图、布局、数据库和服务器的连接等。 使用工程模板,可以标准化不同工程的一系列地图并可确保正确的图层可供所有人直接用于他们的地图中。

  • 未选中 - 将创建工程包。 这是默认设置。
  • 选中 - 将创建工程模板。

Boolean
范围
(可选)

指定用于选择或裁剪要素的范围。

  • 当前显示范围 地图视图 - 范围基于活动地图或场景。 仅在存在活动地图时,才可使用此选项。
  • 绘制范围 构造直角并完成草图 - 范围将基于在地图或场景上绘制的矩形。 此选项将在工程地理数据库中创建要素类并将图层添加至地图。 该要素类的坐标系将与地图相同。
    注:

    环境对话框中不提供此选项。 只能在具有范围数据类型的工具参数中或工具对话框的环境选项卡中找到此选项。

    注:

    当选中从“编辑”选项卡启用和禁用编辑编辑选项时,必须在编辑功能区选项卡上启用编辑才能绘制范围。

  • 图层范围 图层 - 范围基于活动地图图层。 使用下拉列表选择可用图层,或使用所有图层中数据的范围选项获取所有活动地图图层(不包括底图)的组合范围。 仅在存在具有图层的活动地图时,才可使用此选项。

    每个地图图层具有以下选项:

    • 所有要素 全选 - 图层中所有要素的范围。
    • 选定要素基于选定要素的区域 - 图层中选定要素的范围。
    • 可见要素 Extent Indicator - 图层中可见要素的范围。
      注:

      选定要素 基于选定要素的区域可见要素 Extent Indicator 选项中的范围仅适用于要素图层。

  • 浏览 浏览 - 范围基于现有数据集。
  • 输入的交集 相交 - 范围将基于所有输入的最小或交叉范围。 如果输入未重叠,则结果为包含所有零值的空范围。
  • 输入的并集 联合 - 范围将基于所有输入的最大或合并范围。
  • 剪贴板 粘贴 - 可在剪贴板中复制和粘贴范围。
    • 复制范围 复制 - 将范围坐标和坐标系复制到剪贴板。
    • 粘贴范围 粘贴 - 从剪贴板粘贴范围坐标和(可选)坐标系。 如果剪贴板值不包含坐标系,则范围将使用地图的坐标系。
    注:

    将使用与 ArcPy Extent 对象相同的格式和顺序从剪贴板中复制和粘贴范围坐标:x-min、y-min、x-max、y-max 和空间参考。

  • 重置范围 重置 - 将范围重置为默认值。
  • 手动输入坐标 - 坐标必须是数值,并且与活动地图的坐标系相匹配。
    警告:

    地图可能使用与输入的坐标不同的显示单位。 不支持使用主方向(N、S、E、W)。 在南纬和西经坐标中使用负号。

Extent
仅将范围应用到企业级地理数据库图层
(可选)

指定是将指定范围应用到所有图层,还是仅应用到企业级地理数据库图层。

  • 未选中 - 范围将应用到所有图层。 这是默认设置。
  • 选中 - 范围将仅应用到企业级地理数据库图层。

Boolean
附加文件
(可选)

将添加到包中的附加文件。 诸如 .doc.txt.pdf 等附加文件可用于提供有关打包内容和目的的详细信息。

File
摘要
(可选)

将添加到包属性的摘要信息。

String
标签
(可选)

将添加到包属性中的标签。 使用逗号或分号分隔多个标签。

String
包版本
(可选)

指定将在结果包中创建的地理数据库版本。 指定版本可实现与较早版本的 ArcGIS 共享包,并可支持向后兼容。

注:

保存为较早版本的包可能会丢失仅适用于较新版本的属性。

  • 所有版本包中将包含与所有版本(ArcGIS Pro 2.1 和更高版本)均兼容的地理数据库和地图。
  • 当前版本包中包含与当前版本兼容的地理数据库和地图。
  • ArcGIS Pro 2.2此包中将包含与版本 2.2 兼容的地理数据库和地图。
  • ArcGIS Pro 2.3此包中将包含与版本 2.3 兼容的地理数据库和地图。
  • ArcGIS Pro 2.4此包中将包含与版本 2.4 兼容的地理数据库和地图。
  • ArcGIS Pro 2.5此包中将包含与版本 2.5 兼容的地理数据库和地图。
  • ArcGIS Pro 2.6此包中将包含与版本 2.6 兼容的地理数据库和地图。
  • ArcGIS Pro 2.7此包中将包含与版本 2.7 兼容的地理数据库和地图。
  • ArcGIS Pro 2.8此包中将包含与版本 2.8 兼容的地理数据库和地图。
  • ArcGIS Pro 2.9此包中将包含与版本 2.9 兼容的地理数据库和地图。
  • ArcGIS Pro 3.0此包中将包含与版本 3.0 兼容的地理数据库和地图。
  • ArcGIS Pro 3.1此包中将包含与版本 3.1 兼容的地理数据库和地图。
  • ArcGIS Pro 3.2此包中将包含与版本 3.2 兼容的地理数据库和地图。
  • ArcGIS Pro 3.3此包中将包含与版本 3.3 兼容的地理数据库和地图。
String
包括工具箱
(可选)

指定是否合并工程工具箱以及工程工具箱中的工具所引用的数据并将其包括在输出包中。 所有工程都需要默认工具箱,因此无论如何设置,默认工具箱都将包括在内。 连接文件夹中的工具箱不会被视为工程工具箱,且不受此设置的影响。

  • 已选中 - 工程工具箱将包括在输出包中。 这是默认设置。
  • 未选中 - 工程工具箱不会包括在输出包中。
Boolean
包括历史项目
(可选)

指定是否合并地理处理历史项目并将其包括在输出包中。 包括的历史项目将合并重新处理历史项目所需的数据。

  • 将包括历史项目历史项目将包括在输出包中。 这是默认设置。
  • 不会包括历史项目历史项目不会包括在输出包中。
  • 将仅包括有效的历史项目输出包中将仅包括有效的历史项目。 如果找不到任何原始输入图层或工具,则历史项目无效。
String
只读包
(可选)

指定工程是否为只读状态。 无法修改或保存只读工程。

  • 选中 - 工程将为只读状态。
  • 未选中 - 工程将为可写状态。 这是默认设置。
Boolean
仅保留与范围内要素相关的行
(可选)

指定是否将指定的范围应用至相关数据源。

  • 未选中 - 相关的数据源将全部合并。 这是默认设置。
  • 选中 - 仅合并指定范围内与记录对应的相关数据。
Boolean
保留移动地理数据库
(可选)

指定输入移动地理数据库数据是保留在输出中还是写入文件地理数据库格式。 如果输入数据是移动地理数据库网络数据集,则输出将为移动地理数据库。

  • 未选中 - 移动地理数据库数据将被转换为文件地理数据库格式。 这是默认设置。
  • 选中 - 移动地理数据库数据将作为移动地理数据库保留在输出中。 将包含整个地理数据库。
Boolean

arcpy.management.PackageProject(in_project, output_file, {sharing_internal}, {package_as_template}, {extent}, {apply_extent_to_arcsde}, {additional_files}, {summary}, {tags}, {version}, {include_toolboxes}, {include_history_items}, {read_only}, {select_related_rows}, {preserve_sqlite})
名称说明数据类型
in_project

要打包的工程(.aprx 文件)。

File
output_file

输出工程包(.ppkx 文件)。

File
sharing_internal
(可选)

指定是针对内部环境合并工程,还是移动所有数据元素以便在外部共享工程。

  • INTERNAL企业数据源(例如企业级地理数据库和 UNC 路径中的数据)将不会复制到本地文件夹。 这是默认设置。
  • EXTERNAL将复制和保留数据格式(如有可能)。
Boolean
package_as_template
(可选)

指定将创建工程模板还是工程包。 工程模板可以包含地图、布局、数据库和服务器的连接等。 使用工程模板,可以标准化不同工程的一系列地图并可确保正确的图层可供所有人直接用于他们的地图中。

了解有关创建工程模板的详细信息

  • PROJECT_PACKAGE将创建工程包。 这是默认设置。
  • PROJECT_TEMPLATE将创建工程模板。
Boolean
extent
(可选)

指定用于选择或裁剪要素的范围。

  • MAXOF - 将使用的所有输入的最大范围。
  • MINOF - 将使用的所有输入共用的最小范围。
  • DISPLAY - 范围与可见显示范围相等。
  • 图层名称 - 将使用指定图层的范围。
  • Extent 对象 - 将使用指定对象的范围。
  • 以空格分隔的坐标字符串 - 将使用指定字符串的范围。 坐标以 x-min,y-min,x-max,y-max 的顺序表示。
Extent
apply_extent_to_arcsde
(可选)

指定是将指定范围应用到所有图层,还是仅应用到企业级地理数据库图层。

  • ALL指定范围将应用到所有图层。 这是默认设置。
  • ENTERPRISE_ONLY指定范围将仅应用到企业级地理数据库图层。
Boolean
additional_files
[additional_files,...]
(可选)

将添加到包中的附加文件。 诸如 .doc.txt.pdf 等附加文件可用于提供有关打包内容和目的的详细信息。

File
summary
(可选)

将添加到包属性的摘要信息。

String
tags
(可选)

将添加到包属性中的标签。 使用逗号或分号分隔多个标签。

String
version
[version,...]
(可选)

指定将在结果包中创建的地理数据库版本。 指定版本可实现与较早版本的 ArcGIS 共享包,并可支持向后兼容。

注:

保存为较早版本的包可能会丢失仅适用于较新版本的属性。

  • ALL包中将包含与所有版本(ArcGIS Pro 2.1 和更高版本)均兼容的地理数据库和地图。
  • CURRENT包中包含与当前版本兼容的地理数据库和地图。
  • 2.2此包中将包含与版本 2.2 兼容的地理数据库和地图。
  • 2.3此包中将包含与版本 2.3 兼容的地理数据库和地图。
  • 2.4此包中将包含与版本 2.4 兼容的地理数据库和地图。
  • 2.5此包中将包含与版本 2.5 兼容的地理数据库和地图。
  • 2.6此包中将包含与版本 2.6 兼容的地理数据库和地图。
  • 2.7此包中将包含与版本 2.7 兼容的地理数据库和地图。
  • 2.8此包中将包含与版本 2.8 兼容的地理数据库和地图。
  • 2.9此包中将包含与版本 2.9 兼容的地理数据库和地图。
  • 3.0此包中将包含与版本 3.0 兼容的地理数据库和地图。
  • 3.1此包中将包含与版本 3.1 兼容的地理数据库和地图。
  • 3.2此包中将包含与版本 3.2 兼容的地理数据库和地图。
  • 3.3此包中将包含与版本 3.3 兼容的地理数据库和地图。
String
include_toolboxes
(可选)

指定是否合并工程工具箱并将其包括在输出包中。 所有工程都需要默认工具箱,因此无论如何设置,默认工具箱都将包括在内。

  • TOOLBOXES工程工具箱将包括在输出包中。 这是默认设置。
  • NO_TOOLBOXES工程工具箱不会包括在输出包中。
Boolean
include_history_items
(可选)

指定是否合并地理处理历史项目并将其包括在输出包中。 包括的历史项目将合并重新处理历史项目所需的数据。

  • HISTORY_ITEMS历史项目将包括在输出包中。 这是默认设置。
  • NO_HISTORY_ITEMS历史项目不会包括在输出包中。
  • VALID_HISTORY_ITEMS_ONLY输出包中将仅包括有效的历史项目。 如果找不到任何原始输入图层或工具,则历史项目无效。
String
read_only
(可选)

指定工程是否为只读状态。 无法修改或保存只读工程。

  • READ_ONLY工程将为只读状态。
  • READ_WRITE工程将为可写状态。 这是默认设置。
Boolean
select_related_rows
(可选)

指定是否将指定的范围应用至相关数据源。

  • KEEP_ONLY_RELATED_ROWS仅合并指定范围内与记录对应的相关数据。
  • KEEP_ALL_RELATED_ROWS相关的数据源将全部合并。 这是默认设置。
Boolean
preserve_sqlite
(可选)

指定移动地理数据库数据是保留在输出中还是写入文件地理数据库格式。 如果输入数据是移动地理数据库网络数据集,则输出将为移动地理数据库。

  • CONVERT_SQLITE移动地理数据库数据将被转换为文件地理数据库格式。 这是默认设置。
  • PRESERVE_SQLITE移动地理数据库数据将保留在输出中。 将包含整个地理数据库。
Boolean

代码示例

PackageProject 示例 1(Python 窗口)

以下 Python 脚本演示了如何在 Python 窗口中使用 PackageProject 函数。

import arcpy
p = arcpy.mp.ArcGISProject("CURRENT")
arcpy.management.PackageProject(p.filePath, 'E:\\gisShare\\projects\\Pipelines\\SE_Pipeline.ppkx', 'INTERNAL')
PackageProject 示例 2(独立脚本)

以下 Python 脚本将目录中文件名带有单词 oil 的所有工程转到工程包 (.ppkx) 中。

import os
import arcpy

enterpriseProjectDir = "\\\\centralFileServer\\gisData\\ArcGISProProjects"
sharedProjectDir = "c:\\publicFiles\\sharedProjects"

walk = arcpy.da.Walk(enterpriseProjectDir, datatype="Project")

for dirpath, dirnames, filenames in walk:
    for filename in filenames:
        if "oil" in filename.lower():
            project = os.path.join(dirpath, filename)
            outputFile = os.path.join(sharedProjectDir, os.path.splitext(os.path.basename(project))[0] + ".ppkx")
            print("Packaging: {0} to {1}".format(project, outputFile))
            arcpy.management.PackageProject(project, outputFile, "EXTERNAL")

环境

特殊情况

并行处理因子

如果未指定环境,该工具将使用可用内核的二分之一。

许可信息

  • Basic: 是
  • Standard: 是
  • Advanced: 是

相关主题