Programming Python, Part II
One of the Python's looping constructs is for. It is designed to iterate over lists, sets, maps and other iterable objects. In this case, it takes all the items in self._posts and, one by one, assigns them to the variable post. In the body of the for, which is executed on each iteration, we can use the variable post.
The body of the for, as with other constructs that need a piece of code, is delimited by nothing more than the indentation. Here's an example:
>>> the_list = [1,2,3,"a","b"] >>> for item in the_list: ... print item ... 1 2 3 a b >>>
Various tasks are solved with a loop. One such task is doing something for each member of a collection, like we did in the previous example. For those types of tasks, the for construct is excellent.
Another common practice is to perform an action a given number of times—for example, printing “Hello, world” three times. To do that we can use:
>>> a = 0 >>> while a < 3: ... print "Hello world" ... a = a + 1 ... Hello world Hello world Hello world >>>
Another loop construct is while, and it will continue to run its body until the check—that is, the expression after while and before the colon—becomes false.
We can rethink the previous loop as iterating over a list containing the numbers 0–9. There's a way to do it with a for construct:
>>> for a in range(0,3): ... print "Hello world" ... Hello world Hello world Hello world >>>>
This is shorter and arguably more readable. What is while useful for then? It is useful any time you don't really know when you are going to stop the loop. Here are some examples:
Reading characters from a file until you encounter the End of File (EOF).
Reading commands from a user until the user enters the quit command.
Reading temperatures from a sensor until the temperature is too high.
Reading events from a user interface until the user presses the X button at the top of the window to close the program.
There's a pattern forming here—doing something until something else happens. That's what while is good for.
Some time ago, when we didn't have as many choices in programming languages and we ended up using C most of the time, the while construct tended to be much more useful than the for construct. But today, with a powerful for construct, nice functions such as range and the possibility of putting an iterator around anything, for is being used much more than while.
Here's one last example for your enjoyment:
>>> for l in "Hello World": ... print l + " ", ... H e l l o W o r l d
In the fourth line of some previous sample code, if post.is_public(), we have another new construct—an if. This allows programs to make choices based on data. It needs a boolean value and a piece of code. The code is run only if the boolean is True. If you provide something that is not a boolean, Python does its best to interpret it as a boolean. For example, the number 0 is interpreted as False, but all the other numbers as True. Here are some examples:
>>> if True: ... print "It is true!" ... It is true! >>> if False: ... print "Is it false?" ... >>>
We can perform many different types of comparisons on different kinds of objects. Note that the equality operator is ==, not = (that is, two equal signs):
>>> a = 10 >>> if a == 10: ... print "Ten!" ... Ten!
There are other comparisons, such as greater than (>), less than (<) and different (!=). You can experiment with comparisons directly on the REPL:
>>> 3 == 4 False >>> 10 != 5 True >>> 4 >= 1 True
It is common to run a piece of code if something is true and another piece of code if it is false. For example, we could do the following:
if a == 10: print "A is ten." if a != 10: print "A is not ten."
This has a big problem. If we change a to b in the first case, we have to remember to change it in the second. And, the same should be done for any other little changes we do. The solution is an extension to the if construct:
if a == 10: print "A is ten." else: print "A is not ten."
The piece of code after the else will be executed if the first piece wasn't executed.
Another common situation is having various conditionals for different cases. In that case, we use a string of ifs:
if a == 10: print "A is ten." elif a == 0: print "A is zero." elif a != 30: print "A is not thirty." else: print "Who cares about a ?"
elif is the contraction of “else if”, and indeed, the previous code could be written as:
if a == 10: print "A is ten." else: if a == 0: print "A is zero." else: if a != 30: print "A is not thirty." else: print "Who cares about a ?"
But, that is ugly and prone to errors. If you have 10 or 15 different cases, you'll need a 29"-widescreen monitor just to view it. (Not that I have anything against such a monitor. I'd like to have one.)
If you come from other languages that have a switch or select or case construct and are wondering where they are in Python, I'm sorry to disappoint you. Python doesn't have such constructs. There's a proposal to include them, but it hasn't been implemented yet. Right now, the solution is to use a chain of ifs, elifs and elses. After you use this a few times, it's not so bad.
Now that you know about else, here's an interesting tidbit: for and while also can have elses. What do they do? Run Python, and try it out until you discover for yourself. While programming, you'll need to run a lot of code to find out how many undocumented, obscure, almost black-magic, things work, so starting with something simple will help you get some training.
Fast/Flexible Linux OS Recovery
On Demand Now
In this live one-hour webinar, learn how to enhance your existing backup strategies for complete disaster recovery preparedness using Storix System Backup Administrator (SBAdmin), a highly flexible full-system recovery solution for UNIX and Linux systems.
Join Linux Journal's Shawn Powers and David Huffman, President/CEO, Storix, Inc.
Free to Linux Journal readers.Register Now!
|Secure Desktops with Qubes: Installation||May 28, 2016|
|CentOS 6.8 Released||May 27, 2016|
|Secure Desktops with Qubes: Introduction||May 27, 2016|
|Chris Birchall's Re-Engineering Legacy Software (Manning Publications)||May 26, 2016|
|ServersCheck's Thermal Imaging Camera Sensor||May 25, 2016|
|Petros Koutoupis' RapidDisk||May 24, 2016|
- Secure Desktops with Qubes: Introduction
- Download "Linux Management with Red Hat Satellite: Measuring Business Impact and ROI"
- CentOS 6.8 Released
- The Italian Army Switches to LibreOffice
- Linux Mint 18
- ServersCheck's Thermal Imaging Camera Sensor
- Chris Birchall's Re-Engineering Legacy Software (Manning Publications)
- Petros Koutoupis' RapidDisk
- Oracle vs. Google: Round 2
- The FBI and the Mozilla Foundation Lock Horns over Known Security Hole
Until recently, IBM’s Power Platform was looked upon as being the system that hosted IBM’s flavor of UNIX and proprietary operating system called IBM i. These servers often are found in medium-size businesses running ERP, CRM and financials for on-premise customers. By enabling the Power platform to run the Linux OS, IBM now has positioned Power to be the platform of choice for those already running Linux that are facing scalability issues, especially customers looking at analytics, big data or cloud computing.
￼Running Linux on IBM’s Power hardware offers some obvious benefits, including improved processing speed and memory bandwidth, inherent security, and simpler deployment and management. But if you look beyond the impressive architecture, you’ll also find an open ecosystem that has given rise to a strong, innovative community, as well as an inventory of system and network management applications that really help leverage the benefits offered by running Linux on Power.Get the Guide