Python Concepts/Flow control
Boolean Expressions
editPython has a Boolean type. The two values for this type are True and False. Note the capitalization: the first letter must be capitalized. Most text editors, including IDLE, will highlight True and False when properly capitalized.
The bool() Function
editIf you need to convert something into a Boolean value, use the bool()
function. For example:
>>> bool(1)
True
>>> bool(0)
False
>>> bool(500)
True
>>> bool(-1)
True
In Python, the integer 0 evaluates to False
. All other integers will evaluate to True
.[1]
Strings behave similarly: an empty string evaluates to False
, all other strings evaluate to True
.
>>> bool("Hello World!")
True
>>> bool("")
False
>>> bool("True")
True
>>> bool("False")
True
>>> bool("0")
True
Note that what is in the string does not matter: It can be "0", "False" or "ReallyReallyFalse": Everything that is not simply an empty string will evaluate to True.
This means we can write such useful constructs as if ( string )
which will execute a block of code only if the string is non-empty.
Comparison Operators
editPython has a number of built-in comparison operators. They are very versatile and can often be used across data types.
Equality
editThe Python operator for Equality is ==. Let's try it out:
>>> 1 == 1
True
>>> "1" == "1"
True
>>> 2 + 4 == 24
False
>>> "2" + "4" == "24"
True
Conjunction
editThe Python operator for conjunction is and
.
>>> True and False
False
>>> True and True
True
>>> False and False
False
>>> False and True
False
The and
operator works by evaluating until it runs into something False, and return the value that evaluated to False. If everything is True, it returns the last thing it evaluated.
>>> "a" and "b"
'b'
>>> "" and "b"
''
>>> True and 7
7
>>> True and [] and "a"
[]
This means that in a Boolean context the result is evaluated to True or False in the way we would expect, using the actual value means that we can benefit from useful side effects in other contexts.
Disjunction
editThe or
operator works similar to the and
operator. It returns the first value to be True, or the final value if there is no True value.
>>> False or ('a', 'b') or 'c'
('a', 'b')
>>> False or True
True
>>> '' or False
False
>>> '' or False or ()
()
Inversion
editThe not
operator returns the opposite of the value passed to it.
>>> not True
False
>>> not False
True
>>> not 1
False
>>> not 0
True
>>> not ""
True
>>> not "a"
False
>>> not ("a", "")
False
>>> not ("", "a")
False
>>> not ("", "")
False
Interestingly, Python treats the set of strings as having a True value, even if the strings themselves are empty. Since the set the set contains two strings, it really isn't empty, even if the strings are.
Comparison
editThe is
operator compares two values to see if they match. Note that floating point and integer values are not the same thing.
>>> 1 is 1
True
>>> 1 is 2
False
>>> "a" is "a"
True
>>> "a" is "abc"
False
>>> "a" is ("a", "b")
False
>>> 1.0 is 1
False
>>> 1.0 is 1.0
True
is
chains like the and
operator, evaluating to False if any part is False.
>>> 1 is 1 is 1
True
>>> 1 is 1 is 2
False
Contains
editThe in
operator checks a list of things or a string to see if a value is present. Note that floating point and integers evaluate to the same thing for in
. If an array is present then it checks against the whole value of the components of the array, not against the contents of the components in the array.
>>> 1 in (1, 2)
True
>>> 3 in (1, 2)
False
>>> "a" in "abc"
True
>>> "d" in "abc"
False
>>> "a" in ("123", "abc")
False
>>> "a" in ("abc", "123")
False
>>> "abc" in ("abc", "123")
True
>>> 1 in (1.2, 2.0)
False
>>> 1 in (1.0, 2.0)
True
>>> 1.0 in (1, 2)
True
in
needs an array of values to check against, checking in the same way as is
produces an error.
>>> 1 in 1
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: argument of type 'int' is not iterable
Flow Control
editNow that you know all these great ways to work with Booleans, let's use them!
if, elif, and else
editPython the keyword if
to determine if
it should execute a section of code. You can tell which lines are in this section by the level of indentation. The general format of if goes like this:
if [Boolean Expression]: some code rest of code
This allows for very simple logic. What if you want to have two options, similar to case
in other languages? Instead of Case, python uses elif
.
if [Boolean Expression]: code elif [Boolean Expression]: More code else: Even more code rest of program
If the Boolean expression for the first if
is True, nothing in the elif
section will execute, nor will anything in the else section. If there are multiple things that could evaluate to True, use multiple if statements.
That code sample also introduced the else
statement. else
gets executed if the if
statement's Boolean expression, and the Boolean expressions for all the elif
statements (if there are any), evaluate to False.
So, how about some actual code? Here's a simple program; try entering this into IDLE and running it. Don't forget to define the function.
name = raw_input("What is your name?")
if name == "":
print "Hey! You didn't enter a name!"
elif name == "spam" or name == "eggs":
print "A moose once bit my sister!"
else:
print "Nice to meet you, %s." % name
While
editWhile is our first example of a loop. While evaluates a Boolean expression, and if that expression is True, it runs some section of code. It then re-evaluates that Boolean expression: if it still evaluates to True, then it runs again. It keeps running - possibly forever! - until that loop evaluates to False, at which point the program continues with whatever comes after the while loop.
Let's take our previous example. That program ran once, and even if nothing was entered, it was done. Let's suppose we instead want a program that "won't take no for an answer": We'll use a while loop to make the prompt show up again and again until we get some response:
name = raw_input("What is your name?")
while name == "":
print "Hey! You didn't enter a name!"
name = raw_input("Okay, REALLY tell me your name this time:")
if name == "spam" or name == "eggs":
print "A moose once bit my sister!"
else:
print "Nice to meet you, %s" % name
That's even better. However, there are a couple of things I don't like about it. First, I don't like that first Boolean expression. After all, we know that:
bool("") == False
Therefore, wouldn't it make more sense just to test if name is False than to test if it's True that it's equal to ""?
while bool(name) == False:
And do we really want to test if it's True than to Test that it's True that it's equal to False?
while not bool(name):
That's right! Python has a "not" keyword, which acts a lot like ! in other languages.
We're missing one last thing: whatever comes after the "while" is automatically evaluated as a boolean expression. That means that in many cases (this one included) we can leave out the bool()
. (There will still be cases where it's needed, though, so remember that it exists!)
while not name: # This is exactly the same as 'while name == "":', but a lot clearer.
Okay, good? Cool. It's time to add a new feature: The for loop.
For concept in lesson: learn(concept)
editIf you thought the Python idioms for the while loop were cool, the for loop is even better. A for loop takes this basic form syntax-wise:
for [variable name] in [sequence]: code
The for loop will execute enough times that each element of "sequence" is assigned to "variable" once. For example:
for i in [1, 2, 3]:
print i # 1 2 3
Of course, any data type could be within the sequence. While we're at it, let's use a descriptive variable name:
for letter in ['a','b','c']:
print letter # output is a b c
As you can see, then, for loops make it easy to iterate over a sequence, or in simpler terms, to do something with each entry in a list. For loops are also excellent for times when you need to run a while loop a fixed number of times. Let's compare doint that with a for loop and a while loop:
c = 0
while c < 10:
some_function(c)
# code, code code
c += 1
While this is legal Python code, it's not really descriptive. Furthermore, when working with large code blocks, it's easy to forget to add 1 to the variable (in this case 'c') at the end. Fortunately, we can do the same thing with a for loop, in a clearer fashion.
for i in range(10):
some_function(i)
# More code as needed
Note how we don't have to worry about declaring i, or automatically incrementing it. It's also significantly faster, although most of the time your code will run fast enough anyway.
Note that while we used 'i' as the variable name, you could use anything else. As a general rule, when using the variable as a counter, simply use 'i'; this convention is widely followed and helps other programmers know exactly why you chose a for loop. Otherwise, use a descriptive variable name. For example:
list_of_dates = some_function()
for date in list_of_dates:
do_something_with(date)
The main reason we use while loops is sometimes we need to repeatedly prompt a user to get a valid input. Simply put, use while when you don't know or can't calculate how many times a loop will run. If you can, use for.