Syntax
Contents
Syntax#
In this section we’ll learn the basic Python syntax.
Table of Contents
Introduction#
Syntax is set of grammar and punctuation rules that define how to put words and symbols together to properly form a particular language.
In the English language for example, we know a sentence is made up of a subject and predicate, that the first letter should be capitalized, and that it should end in a period, question mark, or exclamation point.
Python is a programming language, intended to read by a computer. In order to write code that the computer can understand, we need to understand the syntax.
Structure#
A program is made up of a series of instructions which are read and executed in order from top to bottom.
To get a better idea of what is involved, lets consider the following simple example:
"""My first program"""
import time
width = 80
today = time.localtime()
greeting = "Hello"
if today.tm_hour < 11:
greeting = "Good morning" # before 12pm
# put together the message and make it centered
message = (greeting + " world!").center(width)
print(message)
Good morning world!
Docstrings#
When the first line of a program or function is enclosed in triple single
('''
) or triple double ("""
) quotes, it is a special kind of string
intended for documentation called a docstring.
1"""My first program"""
Keywords#
Keywords are reserved words that have a special meaning in Python. A keyword cannot be used as a function or variable.
1import time
2import shutil
11if today.tm_hour < 11:
A list of all keywords is available in the keyword
module kwlist
.
Show Keywords
False
None
True
and
as
assert
async
await
break
class
continue
def
del
elif
else
except
finally
for
from
global
if
import
in
is
lambda
nonlocal
not
or
pass
raise
return
try
while
with
yield
Statements#
Code is made up of a series of instructions to the computer called statements.
…
1"""My first program"""
2
3import time
4
5width = 80
6today = time.localtime()
7
8greeting = "Hello"
9
10if today.tm_hour < 11:
11 greeting = "Good morning" # before 12pm
12
13# put together the message and make it centered
14message = (greeting + " world!").center(width)
15
16print(message)
The simple form is a single line of code, kind of like a sentence that says what to do.
1"""My first program"""
2
3import time
See more
4width = 80
5today = time.localtime()
6
7greeting = "Hello"
8
9if today.tm_hour < 11:
10 greeting = "Good morning" # before 12pm
11
12# put together the message and make it centered
13message = (greeting + " world!").center(width)
14
15print(message)
Various kinds of compound statements are used to group together and control part of a program.
HEADER:
BODY
|
statement that dictates how or when |
|
one or more indented statements controlled by |
While the full header syntax depends on the statement, they all begin
with a keyword and end with a colon (:
).
11if today.tm_hour < 11:
12 greeting = "Good morning " # before 12pm
Its body of statements are indented under the header.
11if today.tm_hour < 11:
12 greeting = "Good morning" # before 12pm
Expressions#
A statement may contain one or more expressions, which is any piece of code that resolves to a value.
9greeting = "Hello"
See more
1"""My first program"""
2
3import time
4import shutil
5
6width = 80
7today = time.localtime()
8
9greeting = "Hello"
10
11if today.tm_hour < 11:
12 greeting = "Good morning" # before 12pm
13
14# put together the message and make it centered
15message = (greeting + "world!").center(width)
16
17print(message)
Parentheses can be used around part of an expression to control order of operation or grouping.
15message = (greeting + "world!").center(width)
Often more than one expression is needed to make a value.
One expression is then made up of two or more other expressions, each of which must be evaluated to produce a value, before being combined together into the final result.
They are evaluated in the order of inside outward then left to right.
message = (greeting + "world!").center(width)
message = (greeting + "world!").center(width)
message = (greeting + "world!").center(width)
message = (greeting + "world!").center(width)
Values#
Every value has a type and each type has its own syntax. Let’s take a look at the following example with a summary of the simple types and how variables are saved.
greeting = "Hello." # string (str)
health = 100 # integer (int)
delay = 0.1 # floating point (float)
verbose = True # boolean (bool)
winner = None # NoneType
# list (list)
letters = ["a", "b", "c", "d", "e", "f"]
# dictionary (dict)
numbers = {
"I": 1,
"II": 2,
"III": 3,
"IV": 4,
"V": 5,
}
print(greeting)
Hello.
Variables#
Save a value to be easily used later in the code by giving it a name. To
create a variable simply assign a value to it it using the equals sign
(=
).
Syntax: NAME = VALUE
1greeting = "Hello." # string (str)
2health = 100 # integer (int)
3delay = 0.1 # floating point (float)
4verbose = True # boolean (bool)
5winner = None # NoneType
To reference a variable, or retrieve the data you stored, use the variable name.
7print(greeting)
Assign multiple variables at once by putting the same number of variables on the left of the equals sign as values on the right, separated by commas.
Syntax:
NAME1, NAME2... = VAL1, VAL2...
red, green, blue = 0, 255, 125
Or the same number of variables on the left of the equals sign as elements in a sequence such as a list.
Syntax: NAME1, NAME2... = SEQUENCE
x, y = [-10, 10]
Bracket notation#
Many container types (like lists and dictionaries) support the use of
subscription or bracket notation to select elements from the
collection. Add square brackets ([
]
) after a value enclosing a selector
expression.
Syntax: VALUE[EXPRESSION]
Depending on the type, a selector expression may be a negative or positive index number…
letters[0]
letters[-1]
… a key…
numbers["IV"]
…or a slice.
letters[2:4]
As with any expression, variables can be used in selector expressions.
idx = 2
letters[idx]
letters[idx:]
Bracket notation is most often used on a variable, but in fact it can be used on any expression that results in a type that supports it.
"hello"[2]
list("abc")[-1]
{"a": 1}["a"]
Dot notation#
Use dot notation to access members of a given value by adding a
period (.
) after a value followed by the member name.
Syntax: VALUE.MEMBER
letters.sort()
While dot notation is most often used on a variable, it can actually be used on any expression.
"hello".upper()
This means it is possible to chain or string together multiple attribute references, as long as each consecutive member returns a value.
name = input("Full Name: ").title().strip()
Calls#
Call a function by adding a set of parenthesis after the name.
Syntax: NAME()
print()
Put arguments inside the parenthesis.
Syntax: NAME(ARG)
print("Welcome!")
Welcome!
Separate multiple arguments with commas.
Syntax: NAME(ARG1, ARG2...)
name = "Mario"
print("Welcome", name)
Welcome Mario
Types#
Lets take a closer look at the standard built in types.
Name |
Type |
Description |
Examples |
---|---|---|---|
A single value |
None
|
||
|
Either |
True
False
|
|
|
Whole numbers. |
10
0
-55
|
|
|
Numbers with a decimal point. |
.1
1.5
-0.25
|
|
|
Text data enclosed in either single or double quotes. |
"Hello"
'Goodbye'
|
|
|
An ordered collection of arbitrary objects seperated by commas and enclosed in square brackets ( |
[]
[1, 2, 3]
|
|
|
A collection of |
{}
{"a": 1, "b": 2, "c": 3}
|
|
|
An ordered, immutable collection of arbitrary objects seperated by commas and enclosed in parenthesis ( |
()
(1,)
(1, 2, 3)
1, 2, 3
|
|
|
An unordered collection of unique elements seperated by commas and enclosed in curly braces ( |
set()
{1, 2, 3}
|
Strings#
Strings store text data and can be enclosed in either single or double quotes.
""
"Hello."
'Farewell.'
"It's a lovely day."
'"Well hello!", he said.'
'"Well hello!", he said.'
For a string that spans multiple lines, enclose it in triple double ("""
) or
triple single ('''
) quotes.
rhyme = """Roses are red,
Violets are blue,
Sugar is sweet,
And so are you."""
print(rhyme)
Roses are red,
Violets are blue,
Sugar is sweet,
And so are you.
To break long text into multiple lines of code, put strings on consecutive
lines (without separating commas) and enclose the whole expression in
parentheses (
)
.
text = (
"Lorem ipsum dolor sit amet, consectetur "
"adipiscing elit, sed do eiusmod tempor "
"incididunt ut labore et dolore magna "
"aliqua. Ut enim ad minim veniam, quis "
"nostrud exercitation ullamco laboris "
"nisi ut aliquip ex ea commodo consequat."
)
print(text)
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
Backslashes (\
) are used to escape quotes or to indicate special characters,
like \n
for a new line.
print('It\'s a nice day.')
print("line one\nline two")
It's a nice day.
line one
line two
For strings that contain backslashes use a double backslash (\\
) or prefix
the string with the letter r
for a raw string.
print('"\\n" is used to add a newline')
print(r"C:\Documents\nodes")
"\n" is used to add a newline
C:\Documents\nodes
Strings can be concatenated (joined together) by using
the +
operator.
String literals (the ones in quotes) next to each other are automatically concatenated.
name = "coding class"
print("Welcome to " + name + ".")
text = "Today we're talking about" 'strings.'
print(text)
Welcome to coding class.
Today we're talking aboutstrings.
Use an f-string for string interpolation by prefixing the string with the
letter f
then enclose the variable or other evaluated code curly braces ({
}
).
price = 1.25
count = 5
print(f"I am buying {count} apples for ${price} each.")
print(f"The total is ${price*count}.")
I am buying 5 apples for $1.25 each.
The total is $6.25.
Lists#
A list is an ordered collection of arbitrary objects.
To create one, enclose comma-separated values in square brackets
([
]
), or an empty pair of square brackets for an empty list.
[]
[1, 2, 3]
[1, 2, 3]
Long lists can be split onto multiple lines after the commas.
rainbow = [
"red",
"orange",
"yellow",
"green",
"blue",
"indigo",
"purple",
]
List elements are primarily accessed, changed, or removed using subscription via either index numbers or slices.
# changing
rainbow[-1] = "violet"
# removing
del rainbow[-2]
# accessing
print(rainbow[0])
print(rainbow[-1])
print(rainbow[0:3])
red
violet
['red', 'orange', 'yellow']
Dictionaries#
A dictionary is a collection of key value pairs.
To create one, enclose comma-separated key value pairs in curly braces ({
}
) with
a colon (:
) between each key and value. Or use an empty pair of curly brackets
to make an empty dictionary.
pet = {}
garfield = {"name": "garfield", "kind": "cat", "color": "orange"}
Long dictionaries can be split onto multiple lines after the commas.
toothless = {
"name": "Toothless",
"kind": "dragon",
"color": "black",
"pic": "/|\\{O_O}/|\\",
"age": 24,
}
List elements are primarily accessed, added, changed, or removed using subscription via keys.
# changing
garfield["name"] = "Garfield"
# adding
garfield["pic"] = "(=^o.o^=)__"
# removing
del toothless["age"]
# accessing
print(toothless["name"], ":", toothless["pic"])
print(garfield["name"], ":", garfield["pic"])
Toothless : /|\{O_O}/|\
Garfield : (=^o.o^=)__
Tuples#
A tuple is an immutable collection of arbitrary objects.
To create one, enclose comma-separated values in parenthesis
((
)
), or an empty pair of parenthesis for an empty tuple.
()
(1, 2, 3)
(1, 2, 3)
A tuple can also be created using comma separated values without the parenthesis.
1, 2, 3
(1, 2, 3)
Though parenthesis are required when splitting tuples onto multiple lines.
words = (
"target",
"specify",
"incline",
"college",
"forget",
"recent",
)
Creating a tuple with only one item is a bit tricky, since parenthesis are used for both expression grouping and tuples.
Use a trailing comma to create a tuple with one item.
# parens are interpreted as grouping
# so this is an int instead of a tuple
(1)
1
# use a trailing comma to create a tuple
# with one item
nums = (1,)
print(nums)
# with or without the parenthesis
nums = 1,
print(nums)
(1,)
(1,)
Tuple elements are accessed using subscription via index numbers or slices.
print(words[0])
print(words[-1])
print(words[0:3])
target
recent
('target', 'specify', 'incline')
Tuples are immutable, so items cannot be modified or removed.
Sets#
A set is an unordered collection with no duplicate elements.
To create one, enclose comma-separated values in curly braces
({
}
).
{1, 2, 3, 3, 2, 1}
{1, 2, 3}
Since curly braces are also used for dictionaries, use set()
to create an
empty set.
set()
set()
Sets are unordered, so subscription is not supported.
Flow Control#
if statements#
If statements are used to only execute code under certain conditions.
If statements always start with an if
clause.
if CONDITION:
BODY
|
an expression evaluated in a boolean context |
|
statements to execute if |
In this example, "Would you like a beer?"
will only be printed if age >= 21
.
1import random
2
3age = random.randint(1, 99)
4
5if age >= 21:
6 print("Would you like a beer?")
7elif age >= 12:
8 print("Would you like a soda?")
9elif age >= 5:
10 print("Would you like a juice?")
11else:
12 print("Hello.")
13
An if statement may contain zero or more elif
clauses.
elif CONDITION:
BODY
This example contains two elif
clauses.
1import random
2
3age = random.randint(1, 99)
4
5if age >= 21:
6 print("Would you like a beer?")
7elif age >= 12:
8 print("Would you like a soda?")
9elif age >= 5:
10 print("Would you like a juice?")
11else:
12 print("Hello.")
13
And an if statement may optionally end with an else
clause. These body
statements will be executed if none of the previous conditions are met.
else:
BODY
|
statements to execute if all previous |
In this example, "Hello."
is printed if all preceding conditions evaluated to
False
.
1import random
2
3age = random.randint(1, 99)
4
5if age >= 21:
6 print("Would you like a beer?")
7elif age >= 12:
8 print("Would you like a soda?")
9elif age >= 5:
10 print("Would you like a juice?")
11else:
12 print("Hello.")
13
for loops#
For loops are used to iterate over every element in a sequence and repeat a block of code each time.
for VAR in ITERABLE:
BODY
|
variable name (or comma-separated list of names) to assign each item to |
|
object to iterate over. |
|
statements to execute where |
1for word in ["apple", "banana", "cherry"]:
2 letter = word[0].upper()
3 print(f"{letter} is for: {word}.")
while loops#
A while
loop is used to repeat a block of code as long as an
expression evaluates to True
.
while CONDITION:
BODY
|
an expression evaluated in a boolean context that determines if the loop keeps going |
|
statements to execute each iteration |
1name = ""
2
3while not name:
4 name = input("What is your name? ")
5
6print(f"Hello there {name}!")
7
Functions#
A function is a set of Python instructions or statements that can be executed, or called, later.
def NAME(PARAMS):
BODY
|
name of the function |
|
zero or more comma separated names for variable arguments |
|
statements to execute each time the function is called |
1def line():
2 print("---------------------------")
3
4def see(pet):
5 line()
6 print(pet["name"], "the", pet["color"], pet["kind"])
7 print(pet["pic"])
8
Reference#
Glossary#
Syntax#
- chaining#
- method chaining#
Stringing together multiple dot notation attribute references.
- comment#
Parts in a source-code file which are ignored when the program is run. In Python add a
#
to the beginning a line to indicate that it is a comment. You can also comment out only part of a line by adding#
followed by the comment text to the end of an expression. It is recommended to follow the#
by a single space before the text of the comment.- keyword#
Reserved words that have special meanings in a programming language so that they cannot be used as an identifier. Some examples of keywords in Python are
for
,if
, anddef
.- syntax#
A set of rules that determine how a programming language is understood by the computer. Grammar, but for code.
- assign#
- identifier#
The name that refers to a some programming element, such as a variable, class, function or module.
- variable#
A name given to a value.
See also#
See also
Comments#
You can leave notes for future reference starting with a
#
. This tells Python to ignore everything that follows until the end of the line.A comment doesn’t have to be at the start of the line.