Python Full Course (1st Half)
Python Full Course (1st Half)
1.Python Introduction
1. What is Python?
Python is a popular programming language. It was created by Guido van Rossum, and
released in 1991.
It is used for:
Example:
print("Hello, World!")
2.Python Syntax
On this Part
As we learned in the previous page, Python syntax can be executed by writing directly in the
Command Line:
Hello, World!
Or by creating a python file on the server, using the .py file extension, and running it in the
Command Line:
2. Python Indentation
Example
Syntax Error:
if 5 > 2:
The number of spaces is up to you as a programmer, the most common use is four, but it has
to be at least one.
Example
if 5 > 2:
if 5 > 2:
You have to use the same number of spaces in the same block of code, otherwise Python will
give you an error:
Example
Syntax Error:
if 5 > 2:
Example
Variables in Python:
x=5
y = "Hello, World!"
You will learn more about variables in the Python Variables chapter.
4. Comments
Comments start with a #, and Python will render the rest of the line as a comment:
Example
Comments in Python:
#This is a comment.
print("Hello, World!”)
Python Variables
Variables
Creating Variables
x=5
y = "John"
print(x)
print(y)
Variables do not need to be declared with any particular type, and can even change type after they
have been set.
Example
print(x)
Casting
If you want to specify the data type of a variable, this can be done with casting.
Example
y = int(3) # y will be 3
ADVERTISEMENT
You can get the data type of a variable with the type() function.
Example
x=5
y = "John"
print(type(x))
print(type(y))
You will learn more about data types and casting later in this tutorial.
Example
x = "John"
# is the same as
x = 'John'
Case-Sensitive
Example
a=4
A = "Sally"
Variable Names
A variable can have a short name (like x and y) or a more descriptive name (age, carname,
total_volume). Rules for Python variables:
A variable name can only contain alpha-numeric characters and underscores (A-z, 0-9, and _ )
Variable names are case-sensitive (age, Age and AGE are three different variables)
myvar = "John"
my_var = "John"
_my_var = "John"
myVar = "John"
MYVAR = "John"
myvar2 = "John"
Example
2myvar = "John"
my-var = "John"
my var = "John"
ADVERTISEMENT
Variable names with more than one word can be difficult to read.
There are several techniques you can use to make them more readable:
Camel Case
Each word, except the first, starts with a capital letter:
myVariableName = "John"
Pascal Case
MyVariableName = "John"
Snake Case
my_variable_name = "John"
print(x)
print(y)
print(z)
Note: Make sure the number of variables matches the number of values, or else you will get an
error.
And you can assign the same value to multiple variables in one line:
Example
x = y = z = "Orange"
print(x)
print(y)
print(z)
Unpack a Collection
If you have a collection of values in a list, tuple etc. Python allows you to extract the values into
variables. This is called unpacking.
Example
Unpack a list:
x, y, z = fruits
print(x)
print(y)
print(z)
Output Variables
x = "Python is awesome"
print(x)
x = "Python"
y = "is"
z = "awesome"
print(x, y, z)
Example
x = "Python "
y = "is "
z = "awesome"
print(x + y + z)
Notice the space character after "Python " and "is ", without them the result would be
"Pythonisawesome".
Example
x=5
y = 10
print(x + y)
In the print() function, when you try to combine a string and a number with the + operator, Python
will give you an error:
Example
x=5
y = "John"
print(x + y)
The best way to output multiple variables in the print() function is to separate them with commas,
which even support different data types:
Example
x=5
y = "John"
print(x, y)
Global Variables
Variables that are created outside of a function (as in all of the examples in the previous pages) are
known as global variables.
Global variables can be used by everyone, both inside of functions and outside.
x = "awesome"
def myfunc():
print("Python is " + x)
myfunc()
If you create a variable with the same name inside a function, this variable will be local, and can
only be used inside the function. The global variable with the same name will remain as it was,
global and with the original value.
Example
Create a variable inside a function, with the same name as the global variable
x = "awesome"
def myfunc():
x = "fantastic"
print("Python is " + x)
myfunc()
print("Python is " + x)
ADVERTISEMENT
Normally, when you create a variable inside a function, that variable is local, and can only be used
inside that function.
To create a global variable inside a function, you can use the global keyword.
Example
If you use the global keyword, the variable belongs to the global scope:
def myfunc():
global x
x = "fantastic"
myfunc()
print("Python is " + x)
Also, use the global keyword if you want to change a global variable inside a function.
Example
To change the value of a global variable inside a function, refer to the variable by using the global
keyword:
x = "awesome"
def myfunc():
global x
x = "fantastic"
myfunc()
print("Python is " + x)
Variables can store data of different types, and different types can do different things.
Python has the following data types built-in by default, in these categories:
Text Type: str
You can get the data type of any object by using the type() function:
x=5
print(type(x))
In Python, the data type is set when you assign a value to a variable:
x = 20 int
x = 20.5 float
x = 1j complex
x = True bool
x = b"Hello" bytes
x = bytearray(5) bytearray
x = memoryview(bytes(5)) memoryview
x = None NoneType
ADVERTISEMENT
If you want to specify the data type, you can use the following constructor functions:
x = str("Hello World")str
x = int(20) int
x = float(20.5) float
x = complex(1j) complex
x = range(6) range
x = bool(5) bool
x = bytes(5) bytes
x = bytearray(5) bytearray
x = memoryview(bytes(5)) memoryview
Python Numbers
int
float
complex
Variables of numeric types are created when you assign a value to them:
x=1 # int
y = 2.8 # float
z = 1j # complex
To verify the type of any object in Python, use the type() function:
Example
print(type(x))
print(type(y))
print(type(z))
Int
Int, or integer, is a whole number, positive or negative, without decimals, of unlimited length.
Example
Integers:
x=1
y = 35656222554887711
z = -3255522
print(type(x))
print(type(y))
print(type(z))
Float
Float, or "floating point number" is a number, positive or negative, containing one or more decimals.
Example
Floats:
x = 1.10
y = 1.0
z = -35.59
print(type(x))
print(type(y))
print(type(z))
Float can also be scientific numbers with an "e" to indicate the power of 10.
Example
Floats:
x = 35e3
y = 12E4
z = -87.7e100
print(type(x))
print(type(y))
print(type(z))
ADVERTISEMENT
Complex
Example
Complex:
x = 3+5j
y = 5j
z = -5j
print(type(x))
print(type(y))
print(type(z))
Type Conversion
You can convert from one type to another with the int(), float(), and complex() methods:
Example
x=1 # int
y = 2.8 # float
z = 1j # complex
a = float(x)
b = int(y)
c = complex(x)
print(a)
print(b)
print(c)
print(type(a))
print(type(b))
print(type(c))
Note: You cannot convert complex numbers into another number type.
Random Number
Python does not have a random() function to make a random number, but Python has a built-in
module called random that can be used to make random numbers:
Example
Import the random module, and display a random number between 1 and 9:
import random
print(random.randrange(1, 10))
There may be times when you want to specify a type on to a variable. This can be done with casting.
Python is an object-orientated language, and as such it uses classes to define data types, including
its primitive types.
int() - constructs an integer number from an integer literal, a float literal (by removing all
decimals), or a string literal (providing the string represents a whole number)
float() - constructs a float number from an integer literal, a float literal or a string literal
(providing the string represents a float or an integer)
str() - constructs a string from a wide variety of data types, including strings, integer literals and
float literals
Integers:
x = int(1) # x will be 1
y = int(2.8) # y will be 2
z = int("3") # z will be 3
Example
Floats:
x = float(1) # x will be 1.0
Example
Strings:
Python Strings
Strings
Strings in python are surrounded by either single quotation marks, or double quotation marks.
print("Hello")
print('Hello')
You can use quotes inside a string, as long as they don't match the quotes surrounding the string:
Example
print("It's alright")
Assigning a string to a variable is done with the variable name followed by an equal sign and the
string:
Example
a = "Hello"
print(a)
Multiline Strings
Example
print(a)
Example
print(a)
Note: in the result, the line breaks are inserted at the same position as in the code.
ADVERTISEMENT
Like many other popular programming languages, strings in Python are arrays of bytes representing
unicode characters.
However, Python does not have a character data type, a single character is simply a string with a
length of 1.
Example
Get the character at position 1 (remember that the first character has the position 0):
a = "Hello, World!"
print(a[1])
Since strings are arrays, we can loop through the characters in a string, with a for loop.
Example
for x in "banana":
print(x)
Learn more about For Loops in our Python For Loops chapter.
String Length
Example
a = "Hello, World!"
print(len(a))
Check String
To check if a certain phrase or character is present in a string, we can use the keyword in.
Example
print("free" in txt)
Use it in an if statement:
Example
if "free" in txt:
Check if NOT
To check if a certain phrase or character is NOT present in a string, we can use the keyword not in.
Example
Use it in an if statement:
Example
Slicing
Specify the start index and the end index, separated by a colon, to return a part of the string.
print(b[2:5])
By leaving out the start index, the range will start at the first character:
Example
b = "Hello, World!"
print(b[:5])
ADVERTISEMENT
By leaving out the end index, the range will go to the end:
Example
Get the characters from position 2, and all the way to the end:
b = "Hello, World!"
print(b[2:])
Negative Indexing
Use negative indexes to start the slice from the end of the string:
Example
b = "Hello, World!"
print(b[-5:-2])
Python has a set of built-in methods that you can use on strings.
Upper Case
a = "Hello, World!"
print(a.upper())
Lower Case
Example
a = "Hello, World!"
print(a.lower())
Remove Whitespace
Whitespace is the space before and/or after the actual text, and very often you want to remove this
space.
Example
The strip() method removes any whitespace from the beginning or the end:
ADVERTISEMENT
Replace String
Example
a = "Hello, World!"
print(a.replace("H", "J"))
Split String
The split() method returns a list where the text between the specified separator becomes the list
items.
Example
The split() method splits the string into substrings if it finds instances of the separator:
a = "Hello, World!"
String Concatenation
To concatenate, or combine, two strings you can use the + operator.
a = "Hello"
b = "World"
c=a+b
print(c)
Example
a = "Hello"
b = "World"
c=a+""+b
print(c)
String Format
As we learned in the Python Variables chapter, we cannot combine strings and numbers like this:
age = 36
print(txt)
But we can combine strings and numbers by using f-strings or the format() method!
F-Strings
F-String was introduced in Python 3.6, and is now the preferred way of formatting strings.
To specify a string as an f-string, simply put an f in front of the string literal, and add curly
brackets {} as placeholders for variables and other operations.
Example
Create an f-string:
age = 36
print(txt)
A placeholder can contain variables, operations, functions, and modifiers to format the value.
Example
price = 59
print(txt)
A modifier is included by adding a colon : followed by a legal formatting type, like .2f which
means fixed point number with 2 decimals:
Example
price = 59
print(txt)
Example
print(txt)
Escape Character
An example of an illegal character is a double quote inside a string that is surrounded by double
quotes:
You will get an error if you use double quotes inside a string that is surrounded by double quotes:
txt = "We are the so-called "Vikings" from the north."
Example
The escape character allows you to use double quotes when you normally would not be allowed:
Escape Characters
\\ Backslash
\n New Line
\r Carriage Return
\t Tab
\b Backspace
\f Form Feed
String Methods
Python has a set of built-in methods that you can use on strings.
Note: All string methods return new values. They do not change the original string.
Method Description
endswith() Returns true if the string ends with the specified value
find() Searches the string for a specified value and returns the position of where it was found
index() Searches the string for a specified value and returns the position of where it was found
isalpha() Returns True if all characters in the string are in the alphabet
islower() Returns True if all characters in the string are lower case
isupper() Returns True if all characters in the string are upper case
partition() Returns a tuple where the string is parted into three parts
replace() Returns a string where a specified value is replaced with a specified value
rfind() Searches the string for a specified value and returns the last position of where it was found
rindex()Searches the string for a specified value and returns the last position of where it was found
rpartition() Returns a tuple where the string is parted into three parts
rsplit() Splits the string at the specified separator, and returns a list
split() Splits the string at the specified separator, and returns a list
startswith() Returns true if the string starts with the specified value
swapcase() Swaps cases, lower case becomes upper case and vice versa
zfill() Fills the string with a specified number of 0 values at the beginning
Python Booleans
Boolean Values
When you compare two values, the expression is evaluated and Python returns the Boolean answer:
print(10 > 9)
print(10 == 9)
print(10 < 9)
Example
a = 200
b = 33
if b > a:
else:
The bool() function allows you to evaluate any value, and give you True or False in return,
Example
print(bool(15))
Example
x = "Hello"
y = 15
print(bool(x))
print(bool(y))
ADVERTISEMENT
Any list, tuple, set, and dictionary are True, except empty ones.
Example
bool("abc")
bool(123)
In fact, there are not many values that evaluate to False, except empty values, such as (), [], {}, "",
the number 0, and the value None. And of course the value False evaluates to False.
Example
bool(False)
bool(None)
bool(0)
bool("")
bool(())
bool([])
bool({})
One more value, or object in this case, evaluates to False, and that is if you have an object that is
made from a class with a __len__ function that returns 0 or False:
Example
class myclass():
def __len__(self):
return 0
myobj = myclass()
print(bool(myobj))
def myFunction() :
return True
print(myFunction())
Example
def myFunction() :
return True
if myFunction():
print("YES!")
else:
print("NO!")
Python also has many built-in functions that return a boolean value, like the isinstance() function,
which can be used to determine if an object is of a certain data type:
Example
x = 200
print(isinstance(x, int))
Python Operators
Python Operators
In the example below, we use the + operator to add together two values:
print(10 + 5)
Arithmetic operators
Assignment operators
Comparison operators
Logical operators
Identity operators
Membership operators
Bitwise operators
Arithmetic operators are used with numeric values to perform common mathematical operations:
+ Addition x+y
- Subtraction x-y
* Multiplicationx * y
/ Division x/y
% Modulus x%y
** Exponentiation x ** y
// Floor division x // y
= x=5 x=5
+= x += 3 x = x + 3
-= x -= 3 x = x - 3
*= x *= 3 x = x * 3
/= x /= 3 x = x / 3
%= x %= 3 x = x % 3
//= x //= 3 x = x // 3
**= x **= 3 x = x ** 3
|= x |= 3 x = x | 3
^= x ^= 3 x = x ^ 3
:= print(x := 3) x=3
print(x)
ADVERTISEMENT
== Equal x == y
!= Not equal x != y
and Returns True if both statements are true x < 5 and x < 10
not Reverse the result, returns False if the result is true not(x < 5 and x < 10)
Identity operators are used to compare the objects, not if they are equal, but if they are actually the
same object, with the same memory location:
is not Returns True if both variables are not the same object x is not y
in Returns True if a sequence with the specified value is present in the object x in y
not in Returns True if a sequence with the specified value is not present in the object x not in y
Python Bitwise Operators
<< Zero fill left shift Shift left by pushing zeros in from the right and let the leftmost bits
fall off x << 2
>> Signed right shift Shift right by pushing copies of the leftmost bit in from the left, and
let the rightmost bits fall off x >> 2
Operator Precedence
Example
Parentheses has the highest precedence, meaning that expressions inside parentheses must be
evaluated first:
print((6 + 3) - (6 + 3))
Example
Multiplication * has higher precedence than addition +, and therefor multiplications are evaluated
before additions:
print(100 + 5 * 3)
The precedence order is described in the table below, starting with the highest precedence at the top:
** Exponentiation
^ Bitwise XOR
| Bitwise OR
== != > >= < <= is is not in not in Comparisons, identity, and membership operators
and AND
or OR
If two operators have the same precedence, the expression is evaluated from left to right.
Example
Addition + and subtraction - has the same precedence, and therefor we evaluate the expression from
left to right:
print(5 + 4 - 7 + 3)
Python Lists
List
Create a List:
print(thislist)
List Items
List items are indexed, the first item has index [0], the second item has index [1] etc.
Ordered
When we say that lists are ordered, it means that the items have a defined order, and that order will
not change.
If you add new items to a list, the new items will be placed at the end of the list.
Note: There are some list methods that will change the order, but in general: the order of the items
will not change.
Changeable
The list is changeable, meaning that we can change, add, and remove items in a list after it has been
created.
Allow Duplicates
Since lists are indexed, lists can have items with the same value:
Example
print(thislist)
ADVERTISEMENT
List Length
To determine how many items a list has, use the len() function:
Example
print(len(thislist))
Example
list2 = [1, 5, 7, 9, 3]
Example
type()
From Python's perspective, lists are defined as objects with the data type 'list':
<class 'list'>
Example
print(type(mylist))
It is also possible to use the list() constructor when creating a new list.
Example
print(thislist)
There are four collection data types in the Python programming language:
*Set items are unchangeable, but you can remove and/or add items whenever you like.
**As of Python version 3.7, dictionaries are ordered. In Python 3.6 and earlier, dictionaries are
unordered.
When choosing a collection type, it is useful to understand the properties of that type. Choosing the
right type for a particular data set could mean retention of meaning, and, it could mean an increase
in efficiency or security.
Access Items
List items are indexed and you can access them by referring to the index number:
print(thislist[1])
Negative Indexing
-1 refers to the last item, -2 refers to the second last item etc.
Example
print(thislist[-1])
Range of Indexes
You can specify a range of indexes by specifying where to start and where to end the range.
When specifying a range, the return value will be a new list with the specified items.
Example
print(thislist[2:5])
Note: The search will start at index 2 (included) and end at index 5 (not included).
By leaving out the start value, the range will start at the first item:
Example
This example returns the items from the beginning to, but NOT including, "kiwi":
print(thislist[:4])
By leaving out the end value, the range will go on to the end of the list:
Example
print(thislist[2:])
ADVERTISEMENT
Specify negative indexes if you want to start the search from the end of the list:
Example
This example returns the items from "orange" (-4) to, but NOT including "mango" (-1):
print(thislist[-4:-1])
Example
if "apple" in thislist:
thislist[1] = "blackcurrant"
print(thislist)
To change the value of items within a specific range, define a list with the new values, and refer to
the range of index numbers where you want to insert the new values:
Example
Change the values "banana" and "cherry" with the values "blackcurrant" and "watermelon":
print(thislist)
If you insert more items than you replace, the new items will be inserted where you specified, and
the remaining items will move accordingly:
Example
print(thislist)
Note: The length of the list will change when the number of items inserted does not match the
number of items replaced.
If you insert less items than you replace, the new items will be inserted where you specified, and the
remaining items will move accordingly:
Example
Change the second and third value by replacing it with one value:
thislist[1:3] = ["watermelon"]
print(thislist)
ADVERTISEMENT
Insert Items
To insert a new list item, without replacing any of the existing values, we can use the insert()
method.
Example
thislist.insert(2, "watermelon")
print(thislist)
Note: As a result of the example above, the list will now contain 4 items.
Append Items
To add an item to the end of the list, use the append() method:
thislist.append("orange")
print(thislist)
Insert Items
Example
thislist.insert(1, "orange")
print(thislist)
Note: As a result of the examples above, the lists will now contain 4 items.
ADVERTISEMENT
Extend List
To append elements from another list to the current list, use the extend() method.
Example
thislist.extend(tropical)
print(thislist)
The extend() method does not have to append lists, you can add any iterable object (tuples, sets,
dictionaries etc.).
Example
thislist.extend(thistuple)
print(thislist)
Remove "banana":
thislist.remove("banana")
print(thislist)
If there are more than one item with the specified value, the remove() method removes the first
occurrence:
Example
thislist.remove("banana")
print(thislist)
Example
thislist.pop(1)
print(thislist)
If you do not specify the index, the pop() method removes the last item.
Example
thislist.pop()
print(thislist)
Example
del thislist[0]
print(thislist)
Example
del thislist
thislist.clear()
print(thislist)
You can loop through the list items by using a for loop:
for x in thislist:
print(x)
Learn more about for loops in our Python For Loops Chapter.
You can also loop through the list items by referring to their index number.
Example
Print all items by referring to their index number:
for i in range(len(thislist)):
print(thislist[i])
ADVERTISEMENT
You can loop through the list items by using a while loop.
Use the len() function to determine the length of the list, then start at 0 and loop your way through
the list items by referring to their indexes.
Example
Print all items, using a while loop to go through all the index numbers
i=0
print(thislist[i])
i=i+1
Learn more about while loops in our Python While Loops Chapter.
Looping Using List Comprehension
List Comprehension offers the shortest syntax for looping through lists:
Example
A short hand for loop that will print all items in a list:
List Comprehension
List comprehension offers a shorter syntax when you want to create a new list based on the values of
an existing list.
Example:
Based on a list of fruits, you want a new list, containing only the fruits with the letter "a" in the
name.
Without list comprehension you will have to write a for statement with a conditional test inside:
newlist = []
for x in fruits:
if "a" in x:
newlist.append(x)
print(newlist)
With list comprehension you can do all that with only one line of code:
Example
print(newlist)
ADVERTISEMENT
The Syntax
The return value is a new list, leaving the old list unchanged.
Condition
The condition is like a filter that only accepts the items that valuate to True.
Example
The condition if x != "apple" will return True for all elements other than "apple", making the new
list contain all fruits except "apple".
The condition is optional and can be omitted:
Example
With no if statement:
Iterable
The iterable can be any iterable object, like a list, tuple, set etc.
Example
Example
Expression
The expression is the current item in the iteration, but it is also the outcome, which you can
manipulate before it ends up like a list item in the new list:
Example
Example
The expression can also contain conditions, not like a filter, but as a way to manipulate the
outcome:
Example
List objects have a sort() method that will sort the list alphanumerically, ascending, by default:
print(thislist)
Example
thislist.sort()
print(thislist)
Sort Descending
Example
thislist.sort(reverse = True)
print(thislist)
Example
thislist.sort(reverse = True)
print(thislist)
ADVERTISEMENT
You can also customize your own function by using the keyword argument key = function.
The function will return a number that will be used to sort the list (the lowest number first):
Example
def myfunc(n):
thislist.sort(key = myfunc)
print(thislist)
By default the sort() method is case sensitive, resulting in all capital letters being sorted before
lower case letters:
Example
thislist.sort()
print(thislist)
Luckily we can use built-in functions as key functions when sorting a list.
Example
Perform a case-insensitive sort of the list:
thislist.sort(key = str.lower)
print(thislist)
Reverse Order
What if you want to reverse the order of a list, regardless of the alphabet?
The reverse() method reverses the current sorting order of the elements.
Example
thislist.reverse()
print(thislist)
Copy a List
You cannot copy a list simply by typing list2 = list1, because: list2 will only be a reference to list1,
and changes made in list1 will automatically also be made in list2.
You can use the built-in List method copy() to copy a list.
mylist = thislist.copy()
print(mylist)
Example
mylist = list(thislist)
print(mylist)
You can also make a copy of a list by using the : (slice) operator.
Example
mylist = thislist[:]
print(mylist)
list2 = [1, 2, 3]
print(list3)
Another way to join two lists is by appending all the items from list2 into list1, one by one:
Example
list2 = [1, 2, 3]
for x in list2:
list1.append(x)
print(list1)
Or you can use the extend() method, where the purpose is to add elements from one list to another
list:
Example
list2 = [1, 2, 3]
list1.extend(list2)
print(list1)
List Methods
Python has a set of built-in methods that you can use on lists.
Method Description
extend() Add the elements of a list (or any iterable), to the end of the current list
index() Returns the index of the first element with the specified value
Tuple
Tuple is one of 4 built-in data types in Python used to store collections of data, the other 3 are List,
Set, and Dictionary, all with different qualities and usage.
Create a Tuple:
print(thistuple)
Tuple Items
Tuple items are indexed, the first item has index [0], the second item has index [1] etc.
Ordered
When we say that tuples are ordered, it means that the items have a defined order, and that order
will not change.
Unchangeable
Tuples are unchangeable, meaning that we cannot change, add or remove items after the tuple has
been created.
Allow Duplicates
Since tuples are indexed, they can have items with the same value:
Example
print(thistuple)
ADVERTISEMENT
Tuple Length
To determine how many items a tuple has, use the len() function:
Example
print(len(thistuple))
To create a tuple with only one item, you have to add a comma after the item, otherwise Python will
not recognize it as a tuple.
Example
thistuple = ("apple",)
print(type(thistuple))
#NOT a tuple
thistuple = ("apple")
print(type(thistuple))
Example
tuple2 = (1, 5, 7, 9, 3)
Example
type()
From Python's perspective, tuples are defined as objects with the data type 'tuple':
<class 'tuple'>
Example
print(type(mytuple))
Example
print(thistuple)
There are four collection data types in the Python programming language:
*Set items are unchangeable, but you can remove and/or add items whenever you like.
**As of Python version 3.7, dictionaries are ordered. In Python 3.6 and earlier, dictionaries are
unordered.
When choosing a collection type, it is useful to understand the properties of that type. Choosing the
right type for a particular data set could mean retention of meaning, and, it could mean an increase
in efficiency or security.
You can access tuple items by referring to the index number, inside square brackets:
print(thistuple[1])
Negative Indexing
-1 refers to the last item, -2 refers to the second last item etc.
Example
print(thistuple[-1])
Range of Indexes
You can specify a range of indexes by specifying where to start and where to end the range.
When specifying a range, the return value will be a new tuple with the specified items.
Example
print(thistuple[2:5])
Note: The search will start at index 2 (included) and end at index 5 (not included).
By leaving out the start value, the range will start at the first item:
Example
This example returns the items from the beginning to, but NOT included, "kiwi":
print(thistuple[:4])
By leaving out the end value, the range will go on to the end of the tuple:
Example
This example returns the items from "cherry" and to the end:
print(thistuple[2:])
ADVERTISEMENT
Specify negative indexes if you want to start the search from the end of the tuple:
Example
This example returns the items from index -4 (included) to index -1 (excluded)
print(thistuple[-4:-1])
Example
if "apple" in thistuple:
Tuples are unchangeable, meaning that you cannot change, add, or remove items once the tuple is
created.
Once a tuple is created, you cannot change its values. Tuples are unchangeable, or immutable as it
also is called.
But there is a workaround. You can convert the tuple into a list, change the list, and convert the list
back into a tuple.
y = list(x)
y[1] = "kiwi"
x = tuple(y)
print(x)
Add Items
Since tuples are immutable, they do not have a built-in append() method, but there are other ways to
add items to a tuple.
1. Convert into a list: Just like the workaround for changing a tuple, you can convert it into a list,
add your item(s), and convert it back into a tuple.
Example
Convert the tuple into a list, add "orange", and convert it back into a tuple:
y = list(thistuple)
y.append("orange")
thistuple = tuple(y)
2. Add tuple to a tuple. You are allowed to add tuples to tuples, so if you want to add one item,
(or many), create a new tuple with the item(s), and add it to the existing tuple:
Example
Create a new tuple with the value "orange", and add that tuple:
y = ("orange",)
thistuple += y
print(thistuple)
Note: When creating a tuple with only one item, remember to include a comma after the item,
otherwise it will not be identified as a tuple.
Remove Items
Tuples are unchangeable, so you cannot remove items from it, but you can use the same workaround
as we used for changing and adding tuple items:
Example
Convert the tuple into a list, remove "apple", and convert it back into a tuple:
y = list(thistuple)
y.remove("apple")
thistuple = tuple(y)
Example
del thistuple
print(thistuple) #this will raise an error because the tuple no longer exists
Unpacking a Tuple
When we create a tuple, we normally assign values to it. This is called "packing" a tuple:
Packing a tuple:
But, in Python, we are also allowed to extract the values back into variables. This is called
"unpacking":
Example
Unpacking a tuple:
print(green)
print(yellow)
print(red)
Note: The number of variables must match the number of values in the tuple, if not, you must use an
asterisk to collect the remaining values as a list.
ADVERTISEMENT
Using Asterisk*
If the number of variables is less than the number of values, you can add an * to the variable name
and the values will be assigned to the variable as a list:
Example
print(green)
print(yellow)
print(red)
If the asterisk is added to another variable name than the last, Python will assign values to the
variable until the number of values left matches the number of variables left.
Example
Add a list of values the "tropic" variable:
print(green)
print(tropic)
print(red)
You can loop through the tuple items by using a for loop.
for x in thistuple:
print(x)
Learn more about for loops in our Python For Loops Chapter.
You can also loop through the tuple items by referring to their index number.
for i in range(len(thistuple)):
print(thistuple[i])
ADVERTISEMENT
You can loop through the tuple items by using a while loop.
Use the len() function to determine the length of the tuple, then start at 0 and loop your way
through the tuple items by referring to their indexes.
Example
Print all items, using a while loop to go through all the index numbers:
i=0
print(thistuple[i])
i=i+1
Python - Join Tuples
tuple2 = (1, 2, 3)
print(tuple3)
Multiply Tuples
If you want to multiply the content of a tuple a given number of times, you can use the * operator:
Example
mytuple = fruits * 2
print(mytuple)
Tuple Methods
Python has two built-in methods that you can use on tuples.
Method Description
index() Searches the tuple for a specified value and returns the position of where it was found
Python Sets
Set
Set is one of 4 built-in data types in Python used to store collections of data, the other 3 are List,
Tuple, and Dictionary, all with different qualities and usage.
* Note: Set items are unchangeable, but you can remove items and add new items.
Create a Set:
print(thisset)
Note: Sets are unordered, so you cannot be sure in which order the items will appear.
Set Items
Set items are unordered, unchangeable, and do not allow duplicate values.
Unordered
Unordered means that the items in a set do not have a defined order.
Set items can appear in a different order every time you use them, and cannot be referred to by index
or key.
Unchangeable
Set items are unchangeable, meaning that we cannot change the items after the set has been created.
Once a set is created, you cannot change its items, but you can remove items and add new items.
Example
print(thisset)
Note: The values True and 1 are considered the same value in sets, and are treated as duplicates:
Example
print(thisset)
Note: The values False and 0 are considered the same value in sets, and are treated as duplicates:
Example
print(thisset)
ADVERTISEMENT
To determine how many items a set has, use the len() function.
Example
print(len(thisset))
Example
String, int and boolean data types:
set2 = {1, 5, 7, 9, 3}
Example
type()
From Python's perspective, sets are defined as objects with the data type 'set':
<class 'set'>
Example
print(type(myset))
Example
There are four collection data types in the Python programming language:
*Set items are unchangeable, but you can remove items and add new items.
**As of Python version 3.7, dictionaries are ordered. In Python 3.6 and earlier, dictionaries are
unordered.
When choosing a collection type, it is useful to understand the properties of that type. Choosing the
right type for a particular data set could mean retention of meaning, and, it could mean an increase
in efficiency or security.
Access Items
But you can loop through the set items using a for loop, or ask if a specified value is present in a
set, by using the in keyword.
for x in thisset:
print(x)
Example
print("banana" in thisset)
Example
Change Items
Once a set is created, you cannot change its items, but you can add new items.
Add Items
Once a set is created, you cannot change its items, but you can add new items.
thisset.add("orange")
print(thisset)
Add Sets
To add items from another set into the current set, use the update() method.
Example
thisset.update(tropical)
print(thisset)
The object in the update() method does not have to be a set, it can be any iterable object (tuples,
lists, dictionaries etc.).
Example
thisset.update(mylist)
print(thisset)
Remove Item
thisset.remove("banana")
print(thisset)
Note: If the item to remove does not exist, remove() will raise an error.
Example
thisset.discard("banana")
print(thisset)
Note: If the item to remove does not exist, discard() will NOT raise an error.
You can also use the pop() method to remove an item, but this method will remove a random item,
so you cannot be sure what item that gets removed.
Example
x = thisset.pop()
print(x)
print(thisset)
Note: Sets are unordered, so when using the pop() method, you do not know which item that gets
removed.
Example
print(thisset)
Example
del thisset
print(thisset)
Loop Items
You can loop through the set items by using a for loop:
for x in thisset:
print(x)
Python - Join Sets
Join Sets
The union() and update() methods joins all items from both sets.
The difference() method keeps the items from the first set that are not in the other set(s).
Union
The union() method returns a new set with all items from both sets.
set2 = {1, 2, 3}
set3 = set1.union(set2)
print(set3)
You can use the | operator instead of the union() method, and you will get the same result.
Example
set2 = {1, 2, 3}
print(set3)
All the joining methods and operators can be used to join multiple sets.
When using a method, just add more sets in the parentheses, separated by commas:
Example
set2 = {1, 2, 3}
print(myset)
When using the | operator, separate the sets with more | operators:
Example
print(myset)
The union() method allows you to join a set with other data types, like lists or tuples.
Example
y = (1, 2, 3)
z = x.union(y)
print(z)
Note: The | operator only allows you to join sets with sets, and not with other data types like you
can with the union() method.
Update
The update() method inserts all items from one set into another.
The update() changes the original set, and does not return a new set.
Example
set2 = {1, 2, 3}
set1.update(set2)
print(set1)
Note: Both union() and update() will exclude any duplicate items.
ADVERTISEMENT
Intersection
The intersection() method will return a new set, that only contains the items that are present in both
sets.
Example
set3 = set1.intersection(set2)
print(set3)
You can use the & operator instead of the intersection() method, and you will get the same result.
Example
print(set3)
Note: The & operator only allows you to join sets with sets, and not with other data types like you
can with the intersection() method.
The intersection_update() method will also keep ONLY the duplicates, but it will change the
original set instead of returning a new set.
Example
set1.intersection_update(set2)
print(set1)
The values True and 1 are considered the same value. The same goes for False and 0.
Example
Join sets that contains the values True, False, 1, and 0, and see what is considered as duplicates:
set1 = {"apple", 1, "banana", 0, "cherry"}
set3 = set1.intersection(set2)
print(set3)
Difference
The difference() method will return a new set that will contain only the items from the first set that
are not present in the other set.
Example
set3 = set1.difference(set2)
print(set3)
You can use the - operator instead of the difference() method, and you will get the same result.
Example
print(set3)
Note: The - operator only allows you to join sets with sets, and not with other data types like you
can with the difference() method.
The difference_update() method will also keep the items from the first set that are not in the other
set, but it will change the original set instead of returning a new set.
Example
Use the difference_update() method to keep the items that are not present in both sets:
set1.difference_update(set2)
print(set1)
Symmetric Differences
The symmetric_difference() method will keep only the elements that are NOT present in both sets.
Example
print(set3)
You can use the ^ operator instead of the symmetric_difference() method, and you will get the same
result.
Example
print(set3)
Note: The ^ operator only allows you to join sets with sets, and not with other data types like you
can with the symmetric_difference() method.
The symmetric_difference_update() method will also keep all but the duplicates, but it will change
the original set instead of returning a new set.
Example
Use the symmetric_difference_update() method to keep the items that are not present in both sets:
set1.symmetric_difference_update(set2)
print(set1)
Set Methods
Python has a set of built-in methods that you can use on sets.
difference() - Returns a set containing the difference between two or more sets
difference_update() -= Removes the items in this set that are also included in another,
specified set
intersection() & Returns a set, that is the intersection of two other sets
intersection_update() &= Removes the items in this set that are not present in other, specified
set(s)
issubset() <= Returns whether another set contains this set or not
< Returns whether all items in this set is present in other, specified set(s)
issuperset() >= Returns whether this set contains another set or not
> Returns whether all items in other, specified set(s) is present in this set
symmetric_difference_update() ^= Inserts the symmetric differences from this set and another
union() | Return a set containing the union of sets
update() |= Update the set with the union of this set and others
Python Dictionaries
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
Dictionary
As of Python version 3.7, dictionaries are ordered. In Python 3.6 and earlier, dictionaries are
unordered.
Dictionaries are written with curly brackets, and have keys and values:
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
print(thisdict)
Dictionary Items
Dictionary items are presented in key:value pairs, and can be referred to by using the key name.
Example
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
print(thisdict["brand"])
Ordered or Unordered?
As of Python version 3.7, dictionaries are ordered. In Python 3.6 and earlier, dictionaries are
unordered.
When we say that dictionaries are ordered, it means that the items have a defined order, and that
order will not change.
Unordered means that the items do not have a defined order, you cannot refer to an item by using an
index.
Changeable
Dictionaries are changeable, meaning that we can change, add or remove items after the dictionary
has been created.
Example
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964,
"year": 2020
print(thisdict)
ADVERTISEMENT
Dictionary Length
To determine how many items a dictionary has, use the len() function:
Example
print(len(thisdict))
thisdict = {
"brand": "Ford",
"electric": False,
"year": 1964,
type()
From Python's perspective, dictionaries are defined as objects with the data type 'dict':
<class 'dict'>
Example
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
print(type(thisdict))
Example
Using the dict() method to make a dictionary:
print(thisdict)
There are four collection data types in the Python programming language:
*Set items are unchangeable, but you can remove and/or add items whenever you like.
**As of Python version 3.7, dictionaries are ordered. In Python 3.6 and earlier, dictionaries are
unordered.
When choosing a collection type, it is useful to understand the properties of that type. Choosing the
right type for a particular data set could mean retention of meaning, and, it could mean an increase
in efficiency or security.
Accessing Items
You can access the items of a dictionary by referring to its key name, inside square brackets:
"brand": "Ford",
"model": "Mustang",
"year": 1964
x = thisdict["model"]
There is also a method called get() that will give you the same result:
Example
x = thisdict.get("model")
Get Keys
The keys() method will return a list of all the keys in the dictionary.
Example
x = thisdict.keys()
The list of the keys is a view of the dictionary, meaning that any changes done to the dictionary will
be reflected in the keys list.
Example
Add a new item to the original dictionary, and see that the keys list gets updated as well:
car = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
x = car.keys()
car["color"] = "white"
ADVERTISEMENT
Get Values
The values() method will return a list of all the values in the dictionary.
Example
x = thisdict.values()
The list of the values is a view of the dictionary, meaning that any changes done to the dictionary
will be reflected in the values list.
Example
Make a change in the original dictionary, and see that the values list gets updated as well:
car = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
x = car.values()
car["year"] = 2020
Example
Add a new item to the original dictionary, and see that the values list gets updated as well:
car = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
x = car.values()
car["color"] = "red"
print(x) #after the change
Get Items
The items() method will return each item in a dictionary, as tuples in a list.
Example
x = thisdict.items()
The returned list is a view of the items of the dictionary, meaning that any changes done to the
dictionary will be reflected in the items list.
Example
Make a change in the original dictionary, and see that the items list gets updated as well:
car = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
x = car.items()
car["year"] = 2020
Add a new item to the original dictionary, and see that the items list gets updated as well:
car = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
x = car.items()
car["color"] = "red"
Example
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
}
if "model" in thisdict:
Change Values
You can change the value of a specific item by referring to its key name:
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
thisdict["year"] = 2018
Update Dictionary
The update() method will update the dictionary with the items from the given argument.
Example
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
thisdict.update({"year": 2020})
Adding Items
Adding an item to the dictionary is done by using a new index key and assigning a value to it:
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
thisdict["color"] = "red"
print(thisdict)
Update Dictionary
The update() method will update the dictionary with the items from a given argument. If the item
does not exist, the item will be added.
Example
"brand": "Ford",
"model": "Mustang",
"year": 1964
thisdict.update({"color": "red"})
Removing Items
The pop() method removes the item with the specified key name:
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
thisdict.pop("model")
print(thisdict)
Example
The popitem() method removes the last inserted item (in versions before 3.7, a random item is
removed instead):
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
thisdict.popitem()
print(thisdict)
Example
The del keyword removes the item with the specified key name:
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
del thisdict["model"]
print(thisdict)
Example
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
del thisdict
Example
The clear() method empties the dictionary:
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
thisdict.clear()
print(thisdict)
When looping through a dictionary, the return value are the keys of the dictionary, but there are
methods to return the values as well.
for x in thisdict:
print(x)
Example
for x in thisdict:
print(thisdict[x])
Example
You can also use the values() method to return values of a dictionary:
for x in thisdict.values():
print(x)
Example
You can use the keys() method to return the keys of a dictionary:
for x in thisdict.keys():
print(x)
Example
Loop through both keys and values, by using the items() method:
for x, y in thisdict.items():
print(x, y)
Copy a Dictionary
You cannot copy a dictionary simply by typing dict2 = dict1, because: dict2 will only be a reference
to dict1, and changes made in dict1 will automatically also be made in dict2.
There are ways to make a copy, one way is to use the built-in Dictionary method copy().
"brand": "Ford",
"model": "Mustang",
"year": 1964
mydict = thisdict.copy()
print(mydict)
Example
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
mydict = dict(thisdict)
print(mydict)
Nested Dictionaries
myfamily = {
"child1" : {
"name" : "Emil",
"year" : 2004
},
"child2" : {
"name" : "Tobias",
"year" : 2007
},
"child3" : {
"name" : "Linus",
"year" : 2011
Example
Create three dictionaries, then create one dictionary that will contain the other three dictionaries:
child1 = {
"name" : "Emil",
"year" : 2004
child2 = {
"name" : "Tobias",
"year" : 2007
child3 = {
"name" : "Linus",
"year" : 2011
myfamily = {
"child1" : child1,
"child2" : child2,
"child3" : child3
To access items from a nested dictionary, you use the name of the dictionaries, starting with the outer
dictionary:
Example
print(myfamily["child2"]["name"])
You can loop through a dictionary by using the items() method like this:
Example
for y in obj:
Dictionary Methods
Python has a set of built-in methods that you can use on dictionaries.
Method Description
items() Returns a list containing a tuple for each key value pair
setdefault() Returns the value of the specified key. If the key does not exist: insert the key, with
the specified value
Equals: a == b
Not Equals: a != b
These conditions can be used in several ways, most commonly in "if statements" and loops.
If statement:
a = 33
b = 200
if b > a:
In this example we use two variables, a and b, which are used as part of the if statement to test
whether b is greater than a. As a is 33, and b is 200, we know that 200 is greater than 33, and so we
print to screen that "b is greater than a".
Indentation
Python relies on indentation (whitespace at the beginning of a line) to define scope in the code. Other
programming languages often use curly-brackets for this purpose.
Example
If statement, without indentation (will raise an error):
a = 33
b = 200
if b > a:
ADVERTISEMENT
Elif
The elif keyword is Python's way of saying "if the previous conditions were not true, then try this
condition".
Example
a = 33
b = 33
if b > a:
elif a == b:
In this example a is equal to b, so the first condition is not true, but the elif condition is true, so we
print to screen that "a and b are equal".
Else
The else keyword catches anything which isn't caught by the preceding conditions.
Example
a = 200
b = 33
if b > a:
elif a == b:
else:
In this example a is greater than b, so the first condition is not true, also the elif condition is not
true, so we go to the else condition and print to screen that "a is greater than b".
Example
a = 200
b = 33
if b > a:
else:
Short Hand If
If you have only one statement to execute, you can put it on the same line as the if statement.
Example
Example
a=2
b = 330
You can also have multiple else statements on the same line:
Example
a = 330
b = 330
And
The and keyword is a logical operator, and is used to combine conditional statements:
Example
a = 200
b = 33
c = 500
Or
Example
a = 200
b = 33
c = 500
if a > b or a > c:
Not
The not keyword is a logical operator, and is used to reverse the result of the conditional statement:
Example
a = 33
b = 200
if not a > b:
Nested If
You can have if statements inside if statements, this is called nested if statements.
Example
x = 41
if x > 10:
print("Above ten,")
if x > 20:
else:
if statements cannot be empty, but if you for some reason have an if statement with no content, put
in the pass statement to avoid getting an error.
Example
a = 33
b = 200
if b > a:
pass
Python Loops
while loops
for loops
The while Loop
With the while loop we can execute a set of statements as long as a condition is true.
i=1
while i < 6:
print(i)
i += 1
The while loop requires relevant variables to be ready, in this example we need to define an indexing
variable, i, which we set to 1.
With the break statement we can stop the loop even if the while condition is true:
Example
i=1
while i < 6:
print(i)
if i == 3:
break
i += 1
ADVERTISEMENT
With the continue statement we can stop the current iteration, and continue with the next:
Example
i=0
while i < 6:
i += 1
if i == 3:
continue
print(i)
With the else statement we can run a block of code once when the condition no longer is true:
Example
i=1
while i < 6:
print(i)
i += 1
else:
A for loop is used for iterating over a sequence (that is either a list, a tuple, a dictionary, a set, or a
string).
This is less like the for keyword in other programming languages, and works more like an iterator
method as found in other object-orientated programming languages.
With the for loop we can execute a set of statements, once for each item in a list, tuple, set etc.
for x in fruits:
print(x)
The for loop does not require an indexing variable to set beforehand.
Example
for x in "banana":
print(x)
Example
for x in fruits:
print(x)
if x == "banana":
break
Example
Exit the loop when x is "banana", but this time the break comes before the print:
for x in fruits:
if x == "banana":
break
print(x)
ADVERTISEMENT
With the continue statement we can stop the current iteration of the loop, and continue with the next:
Example
for x in fruits:
if x == "banana":
continue
print(x)
To loop through a set of code a specified number of times, we can use the range() function,
The range() function returns a sequence of numbers, starting from 0 by default, and increments by 1
(by default), and ends at a specified number.
Example
for x in range(6):
print(x)
The range() function defaults to 0 as a starting value, however it is possible to specify the starting
value by adding a parameter: range(2, 6), which means values from 2 to 6 (but not including 6):
Example
print(x)
The range() function defaults to increment the sequence by 1, however it is possible to specify the
increment value by adding a third parameter: range(2, 30, 3):
Example
print(x)
The else keyword in a for loop specifies a block of code to be executed when the loop is finished:
Example
Print all numbers from 0 to 5, and print a message when the loop has ended:
for x in range(6):
print(x)
else:
print("Finally finished!")
Note: The else block will NOT be executed if the loop is stopped by a break statement.
Example
Break the loop when x is 3, and see what happens with the else block:
for x in range(6):
if x == 3: break
print(x)
else:
print("Finally finished!")
Nested Loops
The "inner loop" will be executed one time for each iteration of the "outer loop":
Example
for x in adj:
for y in fruits:
print(x, y)
for loops cannot be empty, but if you for some reason have a for loop with no content, put in the
pass statement to avoid getting an error.
Example
pass
Python Functions
Creating a Function
In Python a function is defined using the def keyword:
def my_function():
Calling a Function
Example
def my_function():
my_function()
Arguments
Arguments are specified after the function name, inside the parentheses. You can add as many
arguments as you want, just separate them with a comma.
The following example has a function with one argument (fname). When the function is called, we
pass along a first name, which is used inside the function to print the full name:
Example
def my_function(fname):
my_function("Emil")
my_function("Tobias")
my_function("Linus")
ADVERTISEMENT
Parameters or Arguments?
The terms parameter and argument can be used for the same thing: information that are passed into
a function.
A parameter is the variable listed inside the parentheses in the function definition.
Number of Arguments
By default, a function must be called with the correct number of arguments. Meaning that if your
function expects 2 arguments, you have to call the function with 2 arguments, not more, and not
less.
Example
my_function("Emil", "Refsnes")
If you try to call the function with 1 or 3 arguments, you will get an error:
Example
my_function("Emil")
If you do not know how many arguments that will be passed into your function, add a * before the
parameter name in the function definition.
This way the function will receive a tuple of arguments, and can access the items accordingly:
Example
def my_function(*kids):
Keyword Arguments
You can also send arguments with the key = value syntax.
The phrase Keyword Arguments are often shortened to kwargs in Python documentations.
If you do not know how many keyword arguments that will be passed into your function, add two
asterisk: ** before the parameter name in the function definition.
This way the function will receive a dictionary of arguments, and can access the items accordingly:
Example
If the number of keyword arguments is unknown, add a double ** before the parameter name:
def my_function(**kid):
my_function("Sweden")
my_function("India")
my_function()
my_function("Brazil")
You can send any data types of argument to a function (string, number, list, dictionary etc.), and it
will be treated as the same data type inside the function.
E.g. if you send a List as an argument, it will still be a List when it reaches the function:
Example
def my_function(food):
for x in food:
print(x)
my_function(fruits)
Return Values
Example
def my_function(x):
return 5 * x
print(my_function(3))
print(my_function(5))
print(my_function(9))
function definitions cannot be empty, but if you for some reason have a function definition with no
content, put in the pass statement to avoid getting an error.
Example
def myfunction():
pass
Positional-Only Arguments
You can specify that a function can have ONLY positional arguments, or ONLY keyword arguments.
To specify that a function can have only positional arguments, add , / after the arguments:
Example
print(x)
my_function(3)
Without the , / you are actually allowed to use keyword arguments even if the function expects
positional arguments:
Example
def my_function(x):
print(x)
my_function(x = 3)
But when adding the , / you will get an error if you try to send a keyword argument:
Example
print(x)
my_function(x = 3)
Keyword-Only Arguments
To specify that a function can have only keyword arguments, add *, before the arguments:
Example
print(x)
my_function(x = 3)
Without the *, you are allowed to use positionale arguments even if the function expects keyword
arguments:
Example
def my_function(x):
print(x)
my_function(3)
But when adding the *, / you will get an error if you try to send a positional argument:
Example
print(x)
my_function(3)
You can combine the two argument types in the same function.
Any argument before the / , are positional-only, and any argument after the *, are keyword-only.
Example
print(a + b + c + d)
my_function(5, 6, c = 7, d = 8)
Recursion
Python also accepts function recursion, which means a defined function can call itself.
Recursion is a common mathematical and programming concept. It means that a function calls
itself. This has the benefit of meaning that you can loop through data to reach a result.
The developer should be very careful with recursion as it can be quite easy to slip into writing a
function which never terminates, or one that uses excess amounts of memory or processor power.
However, when written correctly recursion can be a very efficient and mathematically-elegant
approach to programming.
In this example, tri_recursion() is a function that we have defined to call itself ("recurse"). We use
the k variable as the data, which decrements (-1) every time we recurse. The recursion ends when the
condition is not greater than 0 (i.e. when it is 0).
To a new developer it can take some time to work out how exactly this works, best way to find out is
by testing and modifying it.
Example
Recursion Example
def tri_recursion(k):
result = k + tri_recursion(k - 1)
print(result)
else:
result = 0
return result
tri_recursion(6)
Python Lambda
A lambda function can take any number of arguments, but can only have one expression.
Syntax
lambda arguments : expression
x = lambda a : a + 10
print(x(5))
Example
x = lambda a, b : a * b
print(x(5, 6))
Example
x = lambda a, b, c : a + b + c
print(x(5, 6, 2))
ADVERTISEMENT
The power of lambda is better shown when you use them as an anonymous function inside another
function.
Say you have a function definition that takes one argument, and that argument will be multiplied
with an unknown number:
def myfunc(n):
return lambda a : a * n
Use that function definition to make a function that always doubles the number you send in:
Example
def myfunc(n):
return lambda a : a * n
mydoubler = myfunc(2)
print(mydoubler(11))
Or, use the same function definition to make a function that always triples the number you send in:
Example
def myfunc(n):
return lambda a : a * n
mytripler = myfunc(3)
print(mytripler(11))
Or, use the same function definition to make both functions, in the same program:
Example
def myfunc(n):
return lambda a : a * n
mydoubler = myfunc(2)
mytripler = myfunc(3)
print(mydoubler(11))
print(mytripler(11))
Use lambda functions when an anonymous function is required for a short period of time.
Python Arrays
Note: Python does not have built-in support for Arrays, but Python Lists can be used instead.
Arrays
Note: This page shows you how to use LISTS as ARRAYS, however, to work with arrays in Python
you will have to import a library, like the NumPy library.
What is an Array?
An array is a special variable, which can hold more than one value at a time.
If you have a list of items (a list of car names, for example), storing the cars in single variables
could look like this:
car1 = "Ford"
car2 = "Volvo"
car3 = "BMW"
However, what if you want to loop through the cars and find a specific one? And what if you had
not 3 cars, but 300?
An array can hold many values under a single name, and you can access the values by referring to
an index number.
Example
x = cars[0]
Example
cars[0] = "Toyota"
Use the len() method to return the length of an array (the number of elements in an array).
Example
x = len(cars)
Note: The length of an array is always one more than the highest array index.
ADVERTISEMENT
You can use the for in loop to loop through all the elements of an array.
Example
for x in cars:
print(x)
Example
cars.append("Honda")
You can use the pop() method to remove an element from the array.
Example
Delete the second element of the cars array:
cars.pop(1)
You can also use the remove() method to remove an element from the array.
Example
cars.remove("Volvo")
Note: The list's remove() method only removes the first occurrence of the specified value.
Array Methods
Python has a set of built-in methods that you can use on lists/arrays.
Method Description
extend() Add the elements of a list (or any iterable), to the end of the current list
index() Returns the index of the first element with the specified value
Note: Python does not have built-in support for Arrays, but Python Lists can be used instead.
Python Classes and Objects
Python Classes/Objects
Create a Class
class MyClass:
x=5
Create Object
Example
p1 = MyClass()
print(p1.x)
To understand the meaning of classes we have to understand the built-in __init__() function.
All classes have a function called __init__(), which is always executed when the class is being
initiated.
Use the __init__() function to assign values to object properties, or other operations that are
necessary to do when the object is being created:
Example
Create a class named Person, use the __init__() function to assign values for name and age:
class Person:
self.name = name
self.age = age
p1 = Person("John", 36)
print(p1.name)
print(p1.age)
Note: The __init__() function is called automatically every time the class is being used to create a
new object.
ADVERTISEMENT
The __str__() Function
The __str__() function controls what should be returned when the class object is represented as a
string.
If the __str__() function is not set, the string representation of the object is returned:
Example
class Person:
self.name = name
self.age = age
p1 = Person("John", 36)
print(p1)
Example
class Person:
self.name = name
self.age = age
def __str__(self):
return f"{self.name}({self.age})"
p1 = Person("John", 36)
print(p1)
Object Methods
Objects can also contain methods. Methods in objects are functions that belong to the object.
Example
class Person:
self.name = name
self.age = age
def myfunc(self):
p1 = Person("John", 36)
p1.myfunc()
Note: The self parameter is a reference to the current instance of the class, and is used to access
variables that belong to the class.
It does not have to be named self, you can call it whatever you like, but it has to be the first
parameter of any function in the class:
Example
class Person:
mysillyobject.name = name
mysillyobject.age = age
def myfunc(abc):
p1 = Person("John", 36)
p1.myfunc()
Example
p1.age = 40
Example
del p1.age
Delete Objects
Example
del p1
class definitions cannot be empty, but if you for some reason have a class definition with no content,
put in the pass statement to avoid getting an error.
Example
class Person:
pass
Python Inheritance
Python Inheritance
Inheritance allows us to define a class that inherits all the methods and properties from another
class.
Parent class is the class being inherited from, also called base class.
Child class is the class that inherits from another class, also called derived class.
Any class can be a parent class, so the syntax is the same as creating any other class:
Create a class named Person, with firstname and lastname properties, and a printname method:
class Person:
self.firstname = fname
self.lastname = lname
def printname(self):
print(self.firstname, self.lastname)
#Use the Person class to create an object, and then execute the printname method:
x = Person("John", "Doe")
x.printname()
To create a class that inherits the functionality from another class, send the parent class as a
parameter when creating the child class:
Example
Create a class named Student, which will inherit the properties and methods from the Person class:
class Student(Person):
pass
Note: Use the pass keyword when you do not want to add any other properties or methods to the
class.
Now the Student class has the same properties and methods as the Person class.
Example
Use the Student class to create an object, and then execute the printname method:
x = Student("Mike", "Olsen")
x.printname()
ADVERTISEMENT
So far we have created a child class that inherits the properties and methods from its parent.
We want to add the __init__() function to the child class (instead of the pass keyword).
Note: The __init__() function is called automatically every time the class is being used to create a
new object.
Example
When you add the __init__() function, the child class will no longer inherit the parent's __init__()
function.
Note: The child's __init__() function overrides the inheritance of the parent's __init__() function.
To keep the inheritance of the parent's __init__() function, add a call to the parent's __init__()
function:
Example
class Student(Person):
Now we have successfully added the __init__() function, and kept the inheritance of the parent
class, and we are ready to add functionality in the __init__() function.
Python also has a super() function that will make the child class inherit all the methods and
properties from its parent:
Example
class Student(Person):
super().__init__(fname, lname)
By using the super() function, you do not have to use the name of the parent element, it will
automatically inherit the methods and properties from its parent.
Add Properties
Example
class Student(Person):
super().__init__(fname, lname)
self.graduationyear = 2019
In the example below, the year 2019 should be a variable, and passed into the Student class when
creating student objects. To do so, add another parameter in the __init__() function:
Example
Add a year parameter, and pass the correct year when creating objects:
class Student(Person):
super().__init__(fname, lname)
self.graduationyear = year
Add Methods
Example
class Student(Person):
self.graduationyear = year
def welcome(self):
If you add a method in the child class with the same name as a function in the parent class, the
inheritance of the parent method will be overridden.
Python Iterators
Python Iterators
An iterator is an object that can be iterated upon, meaning that you can traverse through all the
values.
Technically, in Python, an iterator is an object which implements the iterator protocol, which consist
of the methods __iter__() and __next__().
Iterator vs Iterable
Lists, tuples, dictionaries, and sets are all iterable objects. They are iterable containers which you
can get an iterator from.
All these objects have a iter() method which is used to get an iterator:
myit = iter(mytuple)
print(next(myit))
print(next(myit))
print(next(myit))
Example
mystr = "banana"
myit = iter(mystr)
print(next(myit))
print(next(myit))
print(next(myit))
print(next(myit))
print(next(myit))
print(next(myit))
Example
print(x)
Example
mystr = "banana"
for x in mystr:
print(x)
The for loop actually creates an iterator object and executes the next() method for each loop.
ADVERTISEMENT
Create an Iterator
To create an object/class as an iterator you have to implement the methods __iter__() and
__next__() to your object.
As you have learned in the Python Classes/Objects chapter, all classes have a function called
__init__(), which allows you to do some initializing when the object is being created.
The __iter__() method acts similar, you can do operations (initializing etc.), but must always return
the iterator object itself.
The __next__() method also allows you to do operations, and must return the next item in the
sequence.
Example
Create an iterator that returns numbers, starting with 1, and each sequence will increase by one
(returning 1,2,3,4,5 etc.):
class MyNumbers:
def __iter__(self):
self.a = 1
return self
def __next__(self):
x = self.a
self.a += 1
return x
myclass = MyNumbers()
myiter = iter(myclass)
print(next(myiter))
print(next(myiter))
print(next(myiter))
print(next(myiter))
print(next(myiter))
StopIteration
The example above would continue forever if you had enough next() statements, or if it was used in
a for loop.
To prevent the iteration from going on forever, we can use the StopIteration statement.
In the __next__() method, we can add a terminating condition to raise an error if the iteration is
done a specified number of times:
Example
class MyNumbers:
def __iter__(self):
self.a = 1
return self
def __next__(self):
x = self.a
self.a += 1
return x
else:
raise StopIteration
myclass = MyNumbers()
myiter = iter(myclass)
for x in myiter:
print(x)
Python Polymorphism
The word "polymorphism" means "many forms", and in programming it refers to
methods/functions/operators with the same name that can be executed on many objects or classes.
Function Polymorphism
An example of a Python function that can be used on different objects is the len() function.
String
x = "Hello World!"
print(len(x))
Tuple
Example
print(len(mytuple))
Dictionary
For dictionaries len() returns the number of key/value pairs in the dictionary:
Example
thisdict = {
"brand": "Ford",
"model": "Mustang",
"year": 1964
print(len(thisdict))
ADVERTISEMENT
Class Polymorphism
Polymorphism is often used in Class methods, where we can have multiple classes with the same
method name.
For example, say we have three classes: Car, Boat, and Plane, and they all have a method called
move():
Example
class Car:
self.brand = brand
self.model = model
def move(self):
print("Drive!")
class Boat:
self.brand = brand
self.model = model
def move(self):
print("Sail!")
class Plane:
self.brand = brand
self.model = model
def move(self):
print("Fly!")
x.move()
Look at the for loop at the end. Because of polymorphism we can execute the same method for all
three classes.
What about classes with child classes with the same name? Can we use polymorphism there?
Yes. If we use the example above and make a parent class called Vehicle, and make Car, Boat,
Plane child classes of Vehicle, the child classes inherits the Vehicle methods, but can override them:
Example
Create a class called Vehicle and make Car, Boat, Plane child classes of Vehicle:
class Vehicle:
self.brand = brand
self.model = model
def move(self):
print("Move!")
class Car(Vehicle):
pass
class Boat(Vehicle):
def move(self):
print("Sail!")
class Plane(Vehicle):
def move(self):
print("Fly!")
print(x.model)
x.move()
Child classes inherits the properties and methods from the parent class.
In the example above you can see that the Car class is empty, but it inherits brand, model, and
move() from Vehicle.
The Boat and Plane classes also inherit brand, model, and move() from Vehicle, but they both
override the move() method.
Because of polymorphism we can execute the same method for all classes.
Python Scope
A variable is only available from inside the region it is created. This is called scope.
Local Scope
A variable created inside a function belongs to the local scope of that function, and can only be
used inside that function.
def myfunc():
x = 300
print(x)
myfunc()
As explained in the example above, the variable x is not available outside the function, but it is
available for any function inside the function:
Example
The local variable can be accessed from a function within the function:
def myfunc():
x = 300
def myinnerfunc():
print(x)
myinnerfunc()
myfunc()
ADVERTISEMENT
Global Scope
A variable created in the main body of the Python code is a global variable and belongs to the
global scope.
Global variables are available from within any scope, global and local.
Example
x = 300
def myfunc():
print(x)
myfunc()
print(x)
Naming Variables
If you operate with the same variable name inside and outside of a function, Python will treat them
as two separate variables, one available in the global scope (outside the function) and one
available in the local scope (inside the function):
Example
The function will print the local x, and then the code will print the global x:
x = 300
def myfunc():
x = 200
print(x)
myfunc()
print(x)
Global Keyword
If you need to create a global variable, but are stuck in the local scope, you can use the global
keyword.
The global keyword makes the variable global.
Example
If you use the global keyword, the variable belongs to the global scope:
def myfunc():
global x
x = 300
myfunc()
print(x)
Also, use the global keyword if you want to make a change to a global variable inside a function.
Example
To change the value of a global variable inside a function, refer to the variable by using the global
keyword:
x = 300
def myfunc():
global x
x = 200
myfunc()
print(x)
Nonlocal Keyword
The nonlocal keyword is used to work with variables inside nested functions.
The nonlocal keyword makes the variable belong to the outer function.
Example
If you use the nonlocal keyword, the variable will belong to the outer function:
def myfunc1():
x = "Jane"
def myfunc2():
nonlocal x
x = "hello"
myfunc2()
return x
print(myfunc1())
Python Modules
What is a Module?
Create a Module
To create a module just save the code you want in a file with the file extension .py:
ExampleGet your own Python Server
def greeting(name):
Use a Module
Now we can use the module we just created, by using the import statement:
Example
Import the module named mymodule, and call the greeting function:
import mymodule
mymodule.greeting("Jonathan")
Note: When using a function from a module, use the syntax: module_name.function_name.
Variables in Module
The module can contain functions, as already described, but also variables of all types (arrays,
dictionaries, objects etc):
Example
person1 = {
"name": "John",
"age": 36,
"country": "Norway"
Example
Import the module named mymodule, and access the person1 dictionary:
import mymodule
a = mymodule.person1["age"]
print(a)
ADVERTISEMENT
Naming a Module
You can name the module file whatever you like, but it must have the file extension .py
Re-naming a Module
You can create an alias when you import a module, by using the as keyword:
Example
import mymodule as mx
a = mx.person1["age"]
print(a)
Built-in Modules
There are several built-in modules in Python, which you can import whenever you like.
Example
Import and use the platform module:
import platform
x = platform.system()
print(x)
There is a built-in function to list all the function names (or variable names) in a module. The dir()
function:
Example
import platform
x = dir(platform)
print(x)
Note: The dir() function can be used on all modules, also the ones you create yourself.
You can choose to import only parts from a module, by using the from keyword.
Example
The module named mymodule has one function and one dictionary:
def greeting(name):
"name": "John",
"age": 36,
"country": "Norway"
Example
print (person1["age"])
Note: When importing using the from keyword, do not use the module name when referring to
elements in the module. Example: person1["age"], not mymodule.person1["age"]
Python Datetime
Python Dates
A date in Python is not a data type of its own, but we can import a module named datetime to work
with dates as date objects.
import datetime
x = datetime.datetime.now()
print(x)
Date Output
When we execute the code from the example above the result will be:
2024-10-15 05:41:44.681331
The date contains year, month, day, hour, minute, second, and microsecond.
The datetime module has many methods to return information about the date object.
Here are a few examples, you will learn more about them later in this chapter:
Example
import datetime
x = datetime.datetime.now()
print(x.year)
print(x.strftime("%A"))
To create a date, we can use the datetime() class (constructor) of the datetime module.
The datetime() class requires three parameters to create a date: year, month, day.
Example
x = datetime.datetime(2020, 5, 17)
print(x)
The datetime() class also takes parameters for time and timezone (hour, minute, second,
microsecond, tzone), but they are optional, and has a default value of 0, (None for timezone).
ADVERTISEMENT
The datetime object has a method for formatting date objects into readable strings.
The method is called strftime(), and takes one parameter, format, to specify the format of the
returned string:
Example
import datetime
x = datetime.datetime(2018, 6, 1)
print(x.strftime("%B"))
%H Hour 00-23 17
%I Hour 00-12 05
%p AM/PM PM
%M Minute 00-59 41
%S Second 00-59 08
%Z Timezone CST
%C Century20
%% A % character %
Python Math
Python has a set of built-in math functions, including an extensive math module, that allows you
to perform mathematical tasks on numbers.
The min() and max() functions can be used to find the lowest or highest value in an iterable:
print(x)
print(y)
The abs() function returns the absolute (positive) value of the specified number:
Example
x = abs(-7.25)
print(x)
Example
print(x)
ADVERTISEMENT
Python has also a built-in module called math, which extends the list of mathematical functions.
import math
When you have imported the math module, you can start using methods and constants of the
module.
The math.sqrt() method for example, returns the square root of a number:
Example
import math
x = math.sqrt(64)
print(x)
The math.ceil() method rounds a number upwards to its nearest integer, and the math.floor() method
rounds a number downwards to its nearest integer, and returns the result:
Example
import math
x = math.ceil(1.4)
y = math.floor(1.4)
print(x) # returns 2
print(y) # returns 1
Example
import math
x = math.pi
print(x)
In our Math Module Reference you will find a complete reference of all methods and constants
that belongs to the Math module.
Python JSON
JSON in Python
Python has a built-in package called json, which can be used to work with JSON data.
import json
If you have a JSON string, you can parse it by using the json.loads() method.
Example
import json
# some JSON:
# parse x:
y = json.loads(x)
print(y["age"])
If you have a Python object, you can convert it into a JSON string by using the json.dumps() method.
Example
import json
x={
"name": "John",
"age": 30,
y = json.dumps(x)
print(y)
ADVERTISEMENT
You can convert Python objects of the following types, into JSON strings:
dict
list
tuple
string
int
float
True
False
None
Example
Convert Python objects into JSON strings, and print the values:
import json
print(json.dumps(["apple", "bananas"]))
print(json.dumps(("apple", "bananas")))
print(json.dumps("hello"))
print(json.dumps(42))
print(json.dumps(31.76))
print(json.dumps(True))
print(json.dumps(False))
print(json.dumps(None))
When you convert from Python to JSON, Python objects are converted into the JSON (JavaScript)
equivalent:
Python JSON
dict Object
list Array
tuple Array
str String
int Number
float Number
True true
False false
None null
Example
import json
x={
"name": "John",
"age": 30,
"married": True,
"divorced": False,
"children": ("Ann","Billy"),
"pets": None,
"cars": [
print(json.dumps(x))
The example above prints a JSON string, but it is not very easy to read, with no indentations and
line breaks.
The json.dumps() method has parameters to make it easier to read the result:
Example
json.dumps(x, indent=4)
You can also define the separators, default value is (", ", ": "), which means using a comma and a
space to separate each object, and a colon and a space to separate keys from values:
Example
The json.dumps() method has parameters to order the keys in the result:
Example
Use the sort_keys parameter to specify if the result should be sorted or not:
Python RegEx
RegEx can be used to check if a string contains the specified search pattern.
RegEx Module
Python has a built-in package called re, which can be used to work with Regular Expressions.
Import the re module:
import re
RegEx in Python
When you have imported the re module, you can start using regular expressions:
Search the string to see if it starts with "The" and ends with "Spain":
import re
x = re.search("^The.*Spain$", txt)
RegEx Functions
The re module offers a set of functions that allows us to search a string for a match:
Function Description
split Returns a list where the string has been split at each match
ADVERTISEMENT
Metacharacters
\ Signals a special sequence (can also be used to escape special characters) "\d"
| Either or "falls|stays"
Special Sequences
A special sequence is a \ followed by one of the characters in the list below, and has a special
meaning:
\A Returns a match if the specified characters are at the beginning of the string "\AThe"
\b Returns a match where the specified characters are at the beginning or at the end of a word
(the "r" in the beginning is making sure that the string is being treated as a "raw string")
r"\bain"
r"ain\b"
\B Returns a match where the specified characters are present, but NOT at the beginning (or at
the end) of a word
(the "r" in the beginning is making sure that the string is being treated as a "raw string")
r"\Bain"
r"ain\B"
\d Returns a match where the string contains digits (numbers from 0-9) "\d"
\D Returns a match where the string DOES NOT contain digits "\D"
\s Returns a match where the string contains a white space character "\s"
\S Returns a match where the string DOES NOT contain a white space character "\S"
\w Returns a match where the string contains any word characters (characters from a to Z, digits
from 0-9, and the underscore _ character) "\w"
\W Returns a match where the string DOES NOT contain any word characters "\W"
\Z Returns a match if the specified characters are at the end of the string "Spain\Z"
Sets
A set is a set of characters inside a pair of square brackets [] with a special meaning:
[arn] Returns a match where one of the specified characters (a, r, or n) is present
[a-n] Returns a match for any lower case character, alphabetically between a and n
[0123] Returns a match where any of the specified digits (0, 1, 2, or 3) are present
[a-zA-Z] Returns a match for any character alphabetically between a and z, lower case OR
upper case
[+] In sets, +, *, ., |, (), $,{} has no special meaning, so [+] means: return a match for any +
character in the string
import re
x = re.findall("ai", txt)
print(x)
The list contains the matches in the order they are found.
Example
import re
x = re.findall("Portugal", txt)
print(x)
The search() function searches the string for a match, and returns a Match object if there is a match.
If there is more than one match, only the first occurrence of the match will be returned:
Example
import re
x = re.search("\s", txt)
Example
import re
x = re.search("Portugal", txt)
print(x)
The split() function returns a list where the string has been split at each match:
Example
import re
txt = "The rain in Spain"
x = re.split("\s", txt)
print(x)
You can control the number of occurrences by specifying the maxsplit parameter:
Example
import re
x = re.split("\s", txt, 1)
print(x)
The sub() function replaces the matches with the text of your choice:
Example
import re
print(x)
You can control the number of replacements by specifying the count parameter:
Example
import re
print(x)
Match Object
A Match Object is an object containing information about the search and the result.
Note: If there is no match, the value None will be returned, instead of the Match Object.
Example
import re
x = re.search("ai", txt)
The Match object has properties and methods used to retrieve information about the search, and the
result:
.span() returns a tuple containing the start-, and end positions of the match.
.string returns the string passed into the function
.group() returns the part of the string where there was a match
Example
Print the position (start- and end-position) of the first match occurrence.
The regular expression looks for any words that starts with an upper case "S":
import re
x = re.search(r"\bS\w+", txt)
print(x.span())
Example
import re
x = re.search(r"\bS\w+", txt)
print(x.string)
Example
The regular expression looks for any words that starts with an upper case "S":
import re
txt = "The rain in Spain"
x = re.search(r"\bS\w+", txt)
print(x.group())
Note: If there is no match, the value None will be returned, instead of the Match Object.
Python PIP
What is PIP?
Note: If you have Python version 3.4 or later, PIP is included by default.
What is a Package?
Modules are Python code libraries you can include in your project.
Navigate your command line to the location of Python's script directory, and type the following:
Install PIP
If you do not have PIP installed, you can download and install it from this page:
https://pypi.org/project/pip/
Download a Package
Open the command line interface and tell PIP to download the package you want.
Navigate your command line to the location of Python's script directory, and type the following:
Example
ADVERTISEMENT
Using a Package
Example
c = camelcase.CamelCase()
print(c.hump(txt))
Find Packages
Remove a Package
Example
The PIP Package Manager will ask you to confirm that you want to remove the camelcase
package:
Uninstalling camelcase-02.1:
Would remove:
c:\users\Your Name\appdata\local\programs\python\python36-32\lib\site-
packages\camelcase-0.2-py3.6.egg-info
c:\users\Your Name\appdata\local\programs\python\python36-32\lib\site-
packages\camelcase\*
Proceed (y/n)?
Press y and the package will be removed.
List Packages
Use the list command to list all the packages installed on your system:
Example
Result:
Package Version
-----------------------
camelcase 0.2
mysql-connector 2.1.6
pip 18.1
pymongo 3.6.1
setuptools 39.0.1
The try block lets you test a block of code for errors.
The else block lets you execute code when there is no error.
The finally block lets you execute code, regardless of the result of the try- and except blocks.
Exception Handling
When an error occurs, or exception as we call it, Python will normally stop and generate an error
message.
try:
print(x)
except:
Since the try block raises an error, the except block will be executed.
Without the try block, the program will crash and raise an error:
Example
print(x)
Many Exceptions
You can define as many exception blocks as you want, e.g. if you want to execute a special block of
code for a special kind of error:
Example
Print one message if the try block raises a NameError and another for other errors:
try:
print(x)
except NameError:
except:
ADVERTISEMENT
Else
You can use the else keyword to define a block of code to be executed if no errors were raised:
Example
In this example, the try block does not generate any error:
try:
print("Hello")
except:
else:
Finally
The finally block, if specified, will be executed regardless if the try block raises an error or not.
Example
try:
print(x)
except:
finally:
Example
try:
f = open("demofile.txt")
try:
f.write("Lorum Ipsum")
except:
finally:
f.close()
except:
The program can continue, without leaving the file object open.
Raise an exception
x = -1
if x < 0:
You can define what kind of error to raise, and the text to print to the user.
Example
x = "hello"
User Input
The following example asks for the username, and when you entered the username, it gets printed
on the screen:
Python 2.7
Python stops executing when it comes to the input() function, and continues when the user has given
some input.
F-String was introduced in Python 3.6, and is now the preferred way of formatting strings.
F-Strings
Create an f-string:
print(txt)
To format values in an f-string, add placeholders {}, a placeholder can contain variables,
operations, functions, and modifiers to format the value.
Example
price = 59
print(txt)
A modifier is included by adding a colon : followed by a legal formatting type, like .2f which
means fixed point number with 2 decimals:
Example
price = 59
Example
print(txt)
ADVERTISEMENT
Example
print(txt)
Example
price = 59
tax = 0.25
txt = f"The price is {price + (price * tax)} dollars"
print(txt)
Example
price = 49
print(txt)
Example
Use the string method upper()to convert a value into upper case letters:
fruit = "apples"
print(txt)
The function does not have to be a built-in Python method, you can create your own functions and
use them:
Example
def myconverter(x):
return x * 0.3048
print(txt)
More Modifiers
At the beginning of this chapter we explained how to use the .2f modifier to format a number into a
fixed point number with 2 decimals.
There are several other modifiers that can be used to format values:
Example
price = 59000
print(txt)
Formatting Types
: Use a space to insert an extra space before positive numbers (and a minus sign before
negative numbers)
:, Use a comma as a thousand separator
:b Binary format
:d Decimal format
:F Fix point number format, in uppercase format (show inf and nan as INF and NAN)
:g General format
:o Octal format
:n Number format
:% Percentage format
String format()
The format() method can still be used, but f-strings are faster and the preferred way to format
strings.
The next examples in this page demonstrates how to format strings with the format() method.
The format() method also uses curly brackets as placeholders {}, but the syntax is slightly
different:
Example
price = 49
print(txt.format(price))
You can add parameters inside the curly brackets to specify how to convert the value:
Example
Multiple Values
If you want to use more values, just add more values to the format() method:
Example
quantity = 3
itemno = 567
price = 49
Index Numbers
You can use index numbers (a number inside the curly brackets {0}) to be sure the values are placed
in the correct placeholders:
Example
quantity = 3
itemno = 567
price = 49
myorder = "I want {0} pieces of item number {1} for {2:.2f} dollars."
Also, if you want to refer to the same value more than once, use the index number:
Example
age = 36
name = "John"
print(txt.format(age, name))
Named Indexes
You can also use named indexes by entering a name inside the curly brackets {carname}, but then
you must use names when you pass the parameter values txt.format(carname = "Ford"):
Example