data:image/s3,"s3://crabby-images/4547c/4547cbd5bb1fd9cfe91a8e710c92f1182d1063cd" alt="Programming ArcGIS with Python Cookbook(Second Edition)"
Working with time-enabled layers in a data frame
In this recipe, you will learn how to time-enable a layer and data frame. You will then write a script that cycles through the time range for the layer and exports a PDF map showing crimes through time in seven-day intervals.
Getting ready
The DataFrameTime
object provides access to time management operations for time-enabled layers in a data frame. This object is returned when you reference the DataFrame.time
property, and includes properties for retrieving the current time, end time, start time, time step interval, and others that are established by using the Time Slider Options dialog box and then saved with the map document. One or more layers in a data frame must be time-enabled for this functionality to be operational.
How to do it...
Follow these steps to learn how to work with time-enabled layers:
- Open
c:\ArcpyBook\Ch2\Crime_Ch2.mxd
with ArcMap. - In the ArcMap Table Of Contents make sure
Crime
is the active data frame. - Open the Layer Properties dialog box for Burglaries in 2009 by right-clicking on the layer and selecting Properties. Select the Time tab, as shown in the following screenshot:
Enable time for the layer by clicking on the Enable time on this layer checkbox.
- Under Time properties, select Each feature has a single time field for Layer Time:. Select the SPLITDT field for the Time Field:. Define a Time Step Interval: of 7.00 Days, as shown in the following screenshot:
Define the Layer Time Extent: by clicking the Calculate button, circled in the following screenshot:
- Check the Time Step Interval: field. You may need to reset that to 7 Days.
- Click on Apply and then OK.
- In the ArcMap Tools toolbar, select the time slider options button to display the Time Slider Options dialog as shown in the following screenshot:
- On the Time Display tab of the Time Slider Options dialog, make sure Time step interval: is set to 7.0 days. If not, set it to 7.0 days. Do the same for the Time window: option.
- Click on OK.
- Save your map document. It's very important that you save the time-enabled data with your map document. The code you write next won't work unless you do so.
- Open the Python Window.
- Import the
arcpy.mapping
module:import arcpy.mapping as mapping
- Reference the currently active document (
Crime_Ch2.mxd
), and assign the reference to a variable:mxd = mapping.MapDocument("CURRENT")
- Retrieve the
Crime
data frame:df = mapping.ListDataFrames(mxd, "Crime")[0]
- Generate the
DataFrameTime
object:dft = df.time
- Set the
DataFrameTime.currentTime
property to theDataFrameTime.startTime
property:dft.currentTime = dft.startTime
- Start a
while
loop that will loop through the time while thecurrentTime
is less than or equal to theendTime
:while dft.currentTime <= dft.endTime:
- Inside the while loop, create a file for each PDF that will be created, export the PDF, and reset the
currentTime
property. The entirewhile
loop should appear as follows:while dft.currentTime <= dft.endTime: fileName = str(dft.currentTime).split(" ")[0] + ".pdf" mapping.ExportToPDF(mxd,os.path.join(r"C:\ArcpyBook\Ch2", fileName), df) print("Exported " + fileName) dft.currentTime = dft.currentTime + dft.timeStepInterval
- The entire script should appear as follows. You can consult the solution file at
c:\ArcpyBook\code\Ch2\TimeEnabledLayers.py
to verify the accuracy of your code:
How it works…
The DataFrameTime
object provides access to time management operations in a data frame. Several properties of DataFrameTime
, including currentTime
, startTime
, endTime
, and timeStepInterval
, are used in this recipe. Initially, we set the currentTime
property equal to the startTime
property. The initial startTime
was calculated when you set the Time Step Interval: properties in ArcMap. The while
loop was set up to loop as long as the currentTime
property is greater than the endTime
property. Inside the loop, we created a fileName
variable that is set to the currentTime
property, plus an extension of .pdf
. We then called the ExportToPDF()
function, passing in a path and the filename. This should ideally export the page layout view to the PDF file. Finally, we updated the currentTime
property by the timeStepInterval
property that was set to 7.0 days in in the Time Step Interval: properties dialog.