ArcGIS Desktop

  • ArcGIS Pro
  • ArcMap

  • My Profile
  • Help
  • Sign Out
ArcGIS Desktop

ArcGIS Online

The mapping platform for your organization

ArcGIS Desktop

A complete professional GIS

ArcGIS Enterprise

GIS in your enterprise

ArcGIS Developers

Tools to build location-aware apps

ArcGIS Solutions

Free template maps and apps for your industry

ArcGIS Marketplace

Get apps and data for your organization

  • Documentation
  • Support
Esri
  • Sign In
user
  • My Profile
  • Sign Out

ArcMap

  • Home
  • Get Started
  • Map
  • Analyze
  • Manage Data
  • Tools
  • Extensions

Set Data Source

  • Summary
  • Usage
  • Syntax
  • Code sample
  • Environments
  • Licensing information

Summary

Changes the data source on layers within a map document (MXD).

If you are using one of the standard Defense Mapping templates, you can use this tool to reset the sources of all of the layers in the TOC to the new data source.

Usage

  • The Document parameter must be the path to a .mxd on disk and not a map object created with arcpy.mapping.MapDocument().

  • The Data Layer Mapping parameter is a value table that consists of the layer name from the map document and the dataset to which this layer will be resourced.

Syntax

arcpy.defense.SetDataSource(document, datalayer_mapping, {active_data_frame_only})
ParameterExplanationData Type
document

The path to a valid ArcMap document (.mxd) that contains layers for which the source needs to be set. This option doesn't work with the CURRENT keyword or a Map Object, so you will need to specify the path.

File
datalayer_mapping
["layer_name", "dataset_path"]

Specifies the layer name and the dataset that corresponds to the layer.

Value Table
active_data_frame_only
(Optional)

Determines if the active data frame or all the data frames in the current map should be used to update the sources.

  • ACTIVE_DATA_FRAME_ONLY —Only sources for the active data frame in the map document are updated.
  • ALL_DATA_FRAMES —All of the layers in every data frame in the map document will be resourced. This is the default.
Boolean

Code sample

SetDataSource example 1

This example uses the specific names of the data layers and the proper paths to the datasets.

"""
THIS EXAMPLE ASSUMES THAT YOU KNOW THE SPECIFIC NAMES OF THE DATA
LAYERS AND THE PROPER PATHS TO THE DATASETS.
"""

# Importing necessary modules
import arcpy

# Checking out defense mapping extension
arcpy.CheckOutExtension('defense')

# Setting path to mxd
map_document = r'C:\DATA\Example.mxd'

# Calling Set Data Source tool
arcpy.defense.SetDataSource(map_document, r"'ZD040_Named_Location_Point - TextP' C:\TRD4.gdb\MGCP\TextP")
SetDataSource example 2

This example resets the sources for several layers from a map document to the same dataset.

"""
THIS EXAMPLE ASSUMES THAT YOU ARE RESOURCING SEVERAL LAYERS FROM A MAP
DOCUMENT TO THE SAME DATABASE, AND THAT THERE ARE NO GROUPED LAYERS IN THE
MAP DOCUMENT.
"""

# Importing necessary modules
import arcpy, os

# Checking out defense mapping extension
arcpy.CheckOutExtension('defense')

# Setting path to mxd and database
map_document = r'C:\DATA\Example.mxd'
database = r'C:\DATA\Example.gdb'

# Getting the layers from the proper dataframes
map_object = arcpy.mapping.MapDocument(map_document)
data_frame = arcpy.mapping.ListDataFrames(map_object, "BaseMap")[0]
resource_layers = arcpy.mapping.ListLayers(map_object, "*", data_frame)

# Creating an empty string that we can build onto with each layer in the dataframe
source_string = r""
for layer in resource_layers:
    layer_name = layer.name
    feature_class  = os.path.split(layer.dataSource)[1]
    dataset = os.path.split(os.path.split(layer.dataSource)[0])[1]
    new_source = r'{0}\{1}\{2}'.format(database, dataset, feature_class)
    source_string  = source_string + "'{0}' {1};".format(layer_name, new_source)

# Saving and closing the map document objec to remove any locks
map_object.save()
del map_object

# Running Set Data Source on all layers in the map documents data frame
arcpy.defense.SetDataSource(map_document, source_string)

Environments

This tool does not use any geoprocessing environments.

Licensing information

  • Basic: No
  • Standard: Requires Defense Mapping
  • Advanced: Requires Defense Mapping

Related topics

  • An overview of the Utilities toolset

ArcGIS Desktop

  • Home
  • Documentation
  • Support

ArcGIS

  • ArcGIS Online
  • ArcGIS Desktop
  • ArcGIS Enterprise
  • ArcGIS
  • ArcGIS Developer
  • ArcGIS Solutions
  • ArcGIS Marketplace

About Esri

  • About Us
  • Careers
  • Esri Blog
  • User Conference
  • Developer Summit
Esri
Tell us what you think.
Copyright © 2021 Esri. | Privacy | Legal