data:image/s3,"s3://crabby-images/60acb/60acb74134a9a6fa86cc2b439336654b4fa0bcce" alt="Programming ArcGIS 10.1 with Python Cookbook"
Using variables to store data
In Chapter 1, Fundamentals of the Python Language for ArcGIS, we covered the topic of variables, so you should have a basic understanding of these structures. Variables are given a name and assigned a data value in your scripts. These named variables occupy space in your computer's memory and the data contained within these structures can change while a script is running. After the script has finished the memory space occupied by these variables is then released and can be used for other operations.
Getting ready
When writing geoprocessing scripts with Python there will be many times when you will need to create variables to hold data of one type or another. This data can then be used in your script as input parameters for tools and functions, as intermediate data for internal processing, to hold paths to datasets, and for other reasons. In addition, many of the ArcPy functions and tools also return data that can be stored in a variable for further use in your script. In this recipe, you will learn the basic techniques for creating variables and assigning data to them.
How to do it...
Follow these steps to create a script that contains variables that are hardcoded with values and that are returned from a function:
- Open IDLE and create a new script window.
- Save the script to
c:\ArcpyBook\Ch2\WorkingWithVariables.py
. - Import the
arcpy
package:import arcpy
- Create a variable called
path
and assign a value to it:path = "c:/ArcpyBook/data"
- Use the newly-created variable to set the workspace:
arcpy.env.workspace = path
- Call the
ListFields()
function and assign the returned value to a new variable calledfields
:fields = arcpy.ListFields("Building_Permits.shp")
- Start a
for
loop to process each of the field objects contained within thefields
variable:for fld in fields:
- Print the name of each field:
print fld.name
- The entire script should appear as follows:
import arcpy path = "c:/ArcpyBook/data" arcpy.env.workspace = path fields = arcpy.ListFields("Building_Permits.shp") for fld in fields: print fld.name
- Save the script.
How it works...
We created three variables in this script. The first variable, path
, was created and assigned a hard-coded value with a data path. This is an example of a literal variable, meaning that they literally mean exactly what they say. They are distinguished from variables, whose values are not directly determined by their name. The second variable, fields
, is created from the returned value of the ListFields()
function and is a Python list
object containing one or more Field
objects. Each Field
represents a field from the attribute table of a feature class or a standalone table. The final variable is a dynamic variable called fld
. As the for
loop cycles through the list returned by the ListFields()
function, each Field
is assigned to the fld
variable. The name of each field is then printed to the screen.