24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
Exercise: Use Python to create buffers around forest roads
In this course, you will use Python to create treatment areas for invasive plant species within the San Juan
National Forest in the state of Colorado. Part of this process will be to define areas in which chemical and
non-chemical treatments may be used within the forest.
In this exercise, you will create treatment areas for invasive plant species by creating polygons around the
forest roads. These polygons will define the non-chemical treatment areas.
Estimated completion time: 50 minutes
To complete exercises, you need the following:
ArcGIS Pro 3.0 (Basic, Standard, or Advanced)
PyCharm
Note: PyCharm is available as a free download. If you do not have PyCharm installed, the first course
exercise provides instructions for downloading the appropriate version.
- Step 1: Download the data
To complete the exercise, you must download the data. If you have already downloaded and
installed the data, continue to the next step.
- Step 2: Open ArcGIS Pro
Start ArcGIS Pro.
If necessary, sign in to ArcGIS Pro using your ArcGIS Online organizational account.
Near Recent Projects, click Open Another Project .
Note: If you have configured ArcGIS Pro to start without a project template or with a default
project, you will not see the Start page. On the Project tab, click Open, and then click
Open Another Project.
Browse to C:\EsriTraining\PythonGP\Data.
Double-click PythonGP.aprx to open it.
- Step 3: Explore San Juan data
1/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
In this step, you will become familiar with the San Juan National Forest data that you will work with
in this course.
In the Catalog pane, under Folders, expand the PythonGP folder.
This folder contains all of the data that you will need for this course.
If necessary, in the map view, click the San Juan map tab to activate it.
Zoom to the Invasive Plants bookmark.
Remind me how
From the Bookmarks menu, choose Invasive Plants.
Step 3a: Explore San Juan data.
Your map shows a portion of the San Juan National Forest and some of the surrounding
communities. You will notice the location of the invasive plants and their proximity to roads and
water features. You will use Python to create buffer zones around roads to determine the extent
where treatment is needed in the invasive plant areas.
- Step 4: Examine BufferDistance table
In this step, you will examine the data that will be used by your script.
In the Contents pane, right-click the BufferDistance table and choose Open.
2/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
Step 4a: Examine BufferDistance table.
This table is the completed table of buffer distances that will be used to create buffer polygons
around the road features.
Close the BufferDistance table.
Save your project
Note: This data is for training purposes only, so if you are prompted with a warning about
compatibility, click Yes.
Exit ArcGIS Pro.
- Step 5: Set the scripting environment
In this step, you will begin your Python script. For the exercises in this course, you will be using
PyCharm for your IDE.
From the Start menu, browse to and start JetBrains PyCharm.
More information
After the application opens, you will open a project folder and create a new script.
From the Welcome screen, click Open, browse to C:\EsriTraining\PythonGP\Scripts, and
click OK.
Note: If the PyCharm application is already open, you can open the folder from the File
menu.
If you receive a warning message, check the box Trust Projects in C:\EsriTraining\PythonGP,
and then click Trust Project.
Now you will verify that you have set the Python Interpreter for the project. If you do not have the
interpreter set, you will get a warning message and the script will not run.
From the File menu, click Settings.
In the Settings dialog box, expand Project: Scripts, and then click Python Interpreter.
In the dialog box, at the top right, click the configure gear , and then choose Add.
3/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
In the Add Python Interpreter dialog box, click System Interpreter.
On the right, click the ellipsis (...) and browse to C:\Program
Files\ArcGIS\Pro\bin\Python\envs\arcgispro-py3\python.exe.
Note: If you do not see an ArcGIS folder in your Program Files folder, ArcGIS may have been
installed in your Users folder instead. Browse to C:\Users\
<Your_Username>\AppData\Local\Programs\ArcGIS\Pro\bin\Python\envs\arcgispro-
py3\python.exe. (On some systems, the AppData folder is hidden; to reveal the folder, on
the toolbar, click the Show Or Hide Hidden Files And Folders button.
Click OK three times.
Now that you have set the correct Python interpreter, you can create your script.
In the Project window, click the Scripts folder to highlight it.
From the File menu, click New.
Click Python File.
In the New Python File dialog box, name the file BufferRoads.py, and then press Enter.
Your new script, BufferRoads.py, opens in a new script tab.
Now you will open the Python Console. The Python Console is the area that shows the results of
your script and provides a place for testing code snippets.
From the Tools menu, choose Python Or Debug Console.
You are now ready to start writing your script.
- Step 6: Set geoprocessing environments
In this step, you will set two geoprocessing environments.
Before entering any Python code, you will import ArcPy in the Python Console in PyCharm. This
window appears below the BufferRoads.py script window. By importing ArcPy first, you will make
PyCharm aware of the ArcPy libraries.
In the Python Console, type import arcpy, and then press Enter.
PyCharm will take a few moments to import the ArcPy libraries.
In the BufferRoads.py script window, on the first line, type import arcpy, and then
press Enter.
1 import arcpy
4/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
Because you are writing and running your script outside of ArcGIS, you must include this
statement to access ArcGIS Python functionality.
Next, you will enter your geoprocessing workspace.
Documentation is important when writing scripts, especially if you want to share your scripts with
others who may not be familiar with your code. You will add comments to begin each major part
of your script.
In the script window, on the next line, type # Set geoprocessing environments,
and then press Enter.
1 import arcpy
2 # Set geoprocessing environments
Type arcpy.e.
A drop-down list of arcpy functions appears.
Press the Tab key to add the env class to the statement.
1 import arcpy
2 # Set geoprocessing environments
3 arcpy.env
Tip: You can also double-click an item in the list to add it to the script.
Continue the statement by typing .workspace =.
Set your workspace equal to the geodatabase path by typing
r"C:\EsriTraining\PythonGP\Data\SanJuan.gdb".
1 import arcpy
2 # Set geoprocessing environments
3 arcpy.env.workspace = r"C:\EsriTraining\PythonGP\Data\SanJuan.gdb"
Note: Paths in Python are string values, so make sure to enclose the path in quotation marks.
Press Enter.
Next, you will type one more environment setting.
Type arcpy.env.overwriteOutput = True and press Enter.
5/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
1 import arcpy
2 # Set geoprocessing environments
3 arcpy.env.workspace = r"C:\EsriTraining\PythonGP\Data\SanJuan.gdb"
4 arcpy.env.overwriteOutput = True
The overwriteOutput parameter controls whether tools will automatically overwrite any existing
output when your script is run. When set to True, tools will execute and overwrite the output
dataset. When set to False, existing outputs will not be overwritten, and the tool will return an
error.
Tip: Because overwriteOutput is a Boolean data type, you could also type 1 for True or 0 for
False.
- Step 7: Join BufferDistance table to the Roads
The next section of your script will join the BufferDistance table to the Roads feature class. Before
executing the join, you will create four variables that will store the parameters used by the
arcpy.Join function.
In the next line of the script, type # Set parameters used to join the
BufferDistance table to the Roads feature class.
This comment indicates that you are setting the parameters for the Join function.
In the Python Console, type import arcpy, and then press Enter.
Type arcpy.Usage("JoinField_management"), and then press Enter.
Step 7a: Join BufferDistance table to the Roads.
? What are the four required parameters for the JoinField function?
You will store each of these parameters as a variable.
In the script, create four variables with their values as shown in the following table.
Note: Be sure to specify each value as a Python string data type.
Variable name Value
inFeatures Roads
6/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
inField ROUTE_TYPE
joinTable BufferDistance
joinField ROUTE_TYPE
1 import arcpy
2 # Set geoprocessing environments
3 arcpy.env.workspace = r"C:\EsriTraining\PythonGP\Data\SanJuan.gdb"
4 arcpy.env.overwriteOutput = True
5 # Set parameters used to join the BufferDistance table to the Roads feature class
6 inFeatures = "Roads"
7 inField = "ROUTE_TYPE"
8 joinTable = "BufferDistance"
9 joinField = "ROUTE_TYPE"
Next, you will write the code to complete the join. First, you will add a comment to the script that
indicates that the script will create the join.
In the next line of the script, type # Join table to feature class, and then
press Enter.
Type arcpy.Join and add the JoinField_management function from the list.
Note: The name of the function is JoinField_management. The name of the toolbox in which
the function is stored will appear after the function name in your script.
Complete the JoinField_management function by entering the variable parameters you
specified earlier.
1 import arcpy
2 # Set geoprocessing environments
3 arcpy.env.workspace = r"C:\EsriTraining\PythonGP\Data\SanJuan.gdb"
4 arcpy.env.overwriteOutput = True
5 # Set parameters used to join the BufferDistance table to the Roads feature class
6 inFeatures = "Roads"
7 inField = "ROUTE_TYPE"
8 joinTable = "BufferDistance"
9 joinField = "ROUTE_TYPE"
10 # Join table to feature class
11 arcpy.JoinField_management(inFeatures, inField, joinTable, joinField)
Tip: Use the function usage in the Python Console to help you enter the variables in the
correct order.
7/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
- Step 8: Buffer the Roads
Now you are ready to buffer the roads using the joined DISTANCE attribute. Before you execute
the Buffer function, you will store the parameters as variables.
In the next line of script, type # Set parameters used to buffer Roads
feature class.
In the Python console, use the arcpy.Usage function to find the parameters for the Buffer
function.
Tip: You can also refer to Buffer (Analysis) on ArcGIS Pro Help.
? What are the required parameters you will need to enter?
? Do you need to specify a variable for in_features?
Use the following table to add the two needed variables for the Buffer function.
Variable name Value
outBuffers RoadBuffers
buffField DISTANCE
12 # Set parameters used to buffer Roads feature class
13 outBuffers = "RoadBuffers"
14 buffField = "DISTANCE"
Now you are ready to buffer the Roads.
In the next line of the script, type # Buffer the roads based on DISTANCE
attribute.
Write the code to buffer the Roads using the DISTANCE attribute.
12 # Set parameters used to buffer Roads feature class
13 outBuffers = "RoadBuffers"
14 buffField = "DISTANCE"
15 # Buffer the roads based on DISTANCE attribute
16 arcpy.Buffer_analysis(inFeatures, outBuffers, buffField)
8/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
Tip: To help you enter the variables in the correct order, use the arcpy.Usage function in the
Python Console or refer to Buffer on ArcGIS Pro Help.
- Step 9: Run your script
You are now ready to run your script. PyCharm has autosave functionality, so it is not necessary to
save your script before running it.
Note: Make sure that ArcGIS Pro is closed before you run your script. If ArcGIS Pro is open,
the geodatabase will be locked and your Python script will not have write access.
From the Run menu, choose Run... .
In the Rundialog box, choose BufferRoads.
Your script will take a few moments to run. When PyCharm is finished, you should see the
following message at the bottom of the PyCharm window.
Process finished with exit code 0
More information
- Step 10: View RoadBuffers in ArcGIS Pro
Now that your roads buffer is complete, you will look at the results. While there are ways to add
results to a map using a script, it is not done by default like it is when using Python window or
Python script tools within the ArcGIS Pro interface. You will work with these in later exercises. In
this exercise, you will confirm the results of your Python code by manually bringing the resulting
data into ArcGIS Pro.
Start ArcGIS Pro.
Under Recent Projects, choose PythonGP.
In the Catalog pane, under Folders, browse to ..\EsriTraining\PythonGP\Data\SanJuan.gdb.
Drag the RoadBuffers feature class into the San Juan map.
If necessary, zoom to the Invasive Plants bookmark.
9/10
24/10/22, 9:18 Exercise: Use Python to create buffers around forest roads Print Window More informationMore information
Step 10a: View RoadBuffers in ArcGIS Pro.
Note: Your colors may be different from the colors in the graphic.
You will notice that the widths around the roads are varied. This variance is based on the
ROUTE_TYPE attribute.
Save your project.
Exit ArcGIS Pro.
If you are continuing to the next exercise, leave PyCharm open; otherwise, exit PyCharm.
10/10