Summary
Generates tiles from a map or basemap and packages the tiles to create a single compressed .tpk file.
Usage
- The input map must have a description and tags for the tool to execute. To add a description and tags, right-click the map name in the Contents pane, select Properties, and enter a description and tags on the Description tab. 
- By choosing PNG for the Tiling Format parameter, the tool will automatically select the correct format (PNG8, PNG24, or PNG32) based on the specified Level of Display. 
- This tool honors the Parallel Processing Factor environment. If the environment is not set (the default) or is set to 100, full parallel processing will be enabled and the tool will attempt to distribute the work to all the logical cores on the machine. Setting the environment to 0 will disable parallel processing. Specifying a factor between 1 and 99 will cause the tool to determine the percentage of logical cores to use by applying the following formula, rounded up to the nearest integer: 
 .- Parallel Processing Factor / 100 * Logical Cores- If the result of this formula is 0 or 1, parallel processing will not be enabled. 
Syntax
arcpy.management.CreateMapTilePackage(in_map, service_type, output_file, format_type, level_of_detail, {service_file}, {summary}, {tags}, {extent}, {compression_quality}, {package_type}, {min_level_of_detail})| Parameter | Explanation | Data Type | 
| in_map | The map from which tiles will be generated and packaged. | Map | 
| service_type | Specifies whether the tiling scheme will be generated from an existing map service or whether map tiles will be generated for ArcGIS Online, Bing Maps, and Google Maps. 
 | Boolean | 
| output_file | The output map tile package. | File | 
| format_type | Specifies the format of the generated tiles. 
 | String | 
| level_of_detail | The maximum scale at which tiles will be generated for the package. The default is 1. Possible values are 1 through 24. Larger values reflect larger scales that show more detail but take more storage space, while smaller values reflect smaller scales that show less detail and take less storage space. This value must be greater than or equal to min_level_of_detail. | Long | 
| service_file (Optional) | The name of the map service or the XML files to use for the tiling scheme. This parameter is required only when the service_type parameter is EXISTING. | MapServer; File | 
| summary (Optional) | Adds summary information to the properties of the package. | String | 
| tags (Optional) | Adds tag information to the properties of the package. Multiple tags can be added, separated by a comma or semicolon. | String | 
| extent (Optional) | Specifies the extent that will be used to select or clip features. 
 | Extent | 
| compression_quality (Optional) | A value between 1 and 100 for the JPEG compression quality. The default value is 75 for JPEG tile format and zero for other formats. Compression is supported only for JPEG and MIXED format. Choosing a higher value will result in a larger file size with a higher-quality image. Choosing a lower value will result in a smaller file size with a lower-quality image. | Long | 
| package_type (Optional) | Specifies the type of tile package that will be created. 
 | String | 
| min_level_of_detail (Optional) | The minimum scale at which tiles will be generated for the package. The default is 1. Possible values are 1 through 24. Larger values reflect larger scales that show more detail but take more storage space, while smaller values reflect smaller scales that show less detail and take less storage space. This value must be less than or equal to level_of_detail. | Long | 
Code sample
The following Python script demonstrates how to use the CreateMapTilePackage tool from the Python window.
import arcpy
arcpy.env.workspace = "C:/TilePackageExample" 
arcpy.CreateMapTilePackage_management("World Soils", "ONLINE", "Example.tpk", "PNG8", "10")Find and create map tile packages for all maps in a project.
# Name: CreateMapTilePackage.py
# Description: Find all the maps in the project and
#   create a map tile package for each map
# import system modules
import os
import arcpy
# Set environment settings
arcpy.env.overwriteOutput = True
arcpy.env.workspace = "C:/Tilepackages" 
# Loop through the project, find all the maps, and
#   create a map tile package for each map,
#   using the same name as the map
p = arcpy.mp.ArcGISProject("c:\\temp\\myproject.aprx")
for m in p.listMaps():
    print("Packaging " + m.name)
    arcpy.CreateMapTilePackage_management(m, "ONLINE", "{}.tpk".format(m.name), 
                                          "PNG8", "10")Environments
Licensing information
- Basic: Yes
- Standard: Yes
- Advanced: Yes