2.3 在Python中使用循环
Python支持for
循环、while
循环和range()
语句。接下来逐个介绍如何使用它们。
2.3.1 Python中的for循环
Python支持for
循环,它的语法与其他语言(如JavaScript或Java)稍有不同。下面的代码块演示如何在Python中使用for
循环来遍历列表中的元素:
上述的代码段是将三个字母分行打印的。你可以通过在print
语句的后面添加逗号“,”将输出限制在同一行显示(如果指定打印的字符很多,则会“换行”),代码如下所示:
当你希望通过一行而不是多行显示文本中的内容时,可以使用上述形式的代码。
Python还提供了内置函数reversed()
,它可以反转循环的方向,例如:
注意,只有当对象的大小是确定的,或者对象实现了__reversed__()
方法的时候反向遍历的功能才有效。
1. 使用try/except
的for
循环
清单2.2的StringToNums.py
说明了如何对一组从字符串转换而来的整数求和。
清单2.2 StringToNums.py
清单2.2首先初始化变量line
、sum
和invalidStr
,然后显示line
的内容。接下来将line
中的内容分割为单词,然后通过try
代码块逐个将单词的数值累加到变量sum
中。如果发生异常,则将当前str
的内容追加到变量invalidStr
。
当循环执行结束,清单2.2打印出数值单词的和,并在后面显示非数值单词。它的输出如下所示:
2. 指数运算
清单2.3的Nth_exponet.py
说明了如何计算一组整数的幂。
清单2.3 Nth_exponet.py
清单2.3中有一个pwr()
函数,其参数为一个数值。此函数中的循环可打印出参数的1到n
次方,n
的取值范围在1
到maxCount+1
之间。
代码的第二部分通过一个for
循环调用pwr()
函数从1
到maxCount+1
的值。它的输出如下所示:
3. 嵌套的循环
清单2.4的Triangular1.py
说明了如何打印一行连续整数(从1
开始),其中每一行的长度都比前一行大1。
清单2.4 Triangular1.py
清单2.4首先初始化max
变量为8
,之后通过变量x
从1
到max+1
执行循环。内层循环有一个值为从1
到x+1
的循环变量y
,并打印y
的值。它的输出如下所示:
4. 在for
循环中使用split()
函数
Python支持各种便捷的字符串操作相关函数,包括split()
函数和join()
函数。在需要将一行文本分词化(即“分割”)为单词,然后使用for
循环遍历这些单词时,split()
函数非常有用。
join()
函数与split()
函数相反,它将两个或多个单词“连接”为一行。通过使用split()
函数,你可以轻松地删除句子中多余的空格,然后调用join()
函数,使文本行中每个单词之间只有一个空格。
(1)使用split()
函数做单词比较
清单2.5的Compare2.py
说明了如何通过split()
函数将文本字符串中的每个单词与另一个单词进行比较。
清单2.5 Compare2.py
清单2.5通过split()
函数对字符串x
中的每个单词与单词abc
进行比较。如果单词精确匹配,就将identical
变量加1;否则就尝试不区分大小写进行比较,若匹配就将casematch
变量加1。
清单2.5的输出如下所示:
(2)使用split()
函数打印指定格式的文本
清单2.6的FixedColumnCount1.py
说明了如何打印一组设定固定宽度的字符串。
清单2.6 FixedColumnCount1.py
清单2.6首先初始化变量wordCount
和str1
,然后执行两个for
循环。第一个for
循环对str1
的每个单词进行左对齐打印,第二个for
循环对str1
的每个单词进行右对齐打印。在每个循环中当wordCount
是偶数的时候就输出一次换行,这样每打印两个连续的单词之后就换行。清单2.6的输出如下所示:
(3)使用split()
函数打印固定宽度的文本
清单2.7的FixedColumnWidth1.py
说明了如何打印固定宽度的文本。
清单2.7 FixedColumnWidth1.py
清单2.7初始化整型变量columnWidth
和字符串类型变量str1
。变量strLen
是str1
的长度,变量rowCount
是strLen
除以columnWidth
的值。之后通过循环打印rowCount
行,每行包含columnWidth
个字符。代码的最后部分输出所有“剩余”的字符。清单2.7的输出如下所示:
(4)使用split()
函数比较文本字符串
清单2.8的CompareStrings1.py
说明了如何判断一个文本字符串中的单词是否出现在另一个文本字符串中。
清单2.8 CompareStrings1.py
清单2.8首先初始化两个字符串变量text1
和text2
,然后通过条件逻辑判断字符串text2
是否包含了text1
(并输出相应打印信息)。
清单2.8的后半部分通过一个循环遍历字符串text1
中的每个单词,并判断其是否出现在text2
中。如果发现有匹配失败的情况,就设置变量subStr
为False
,并通过break
语句跳出循环,提前终止for
循环的执行。最后根据变量subStr
的值打印对应的信息。清单2.8的输出如下所示:
5. 用基础的for
循环显示字符串中的字符
清单2.9的StringChars1.py
说明了如何打印一个文本字符串中的字符。
清单2.9 StringChars1.py
清单2.9的代码简单直接地通过一个for
循环遍历字符串text
并打印它的每个字符以及字符的ord
值(ASCII码)。清单2.9的输出如下所示:
6. join()
函数
另一个去掉多余空格的方法是使用join()
函数,代码示例如下所示:
split()
函数将一个文本字符串“分割”为一系列的单词,同时去掉多余的空格。接下来join()
函数使用一个空格作为分隔符将字符串text1
中的单词连接在一起。上述代码的最后部分使用字符串XYZ
替换空格作为分隔符,执行相同的连接操作。
上述代码的输出如下:
2.3.2 Python中的while
循环
你可以通过如下方式定义一个while
循环来遍历一组数字:
Python通过缩进来组织代码段,而不是像其他语言(如JavaScrip和Java)那样使用花括号。尽管在第3章才会讨论Python的列表数据结构,但你可以大致理解下面的简单代码块,它是上述while
循环的另一种形式,你可以在使用列表时用到:
上述的while
代码段在lst
变量为空的时候终止循环,它不需要显式地检查列表是否为空。它的输出如下所示:
至此我们总结了如何通过split()
函数处理文本字符串中的单词和字符。
1. 使用while
循环寻找一个数的因数
清单2.10的代码通过while
循环、条件逻辑和%(取模)运算符来寻找一个大于1的任意整数的因数。
清单2.10 Divisors.py
清单2.10定义一个函数divisors()
,用整数num
作为入参,并初始化变量div
值为2
。在while
循环里,当num
除以div
的余数为0
的时候就打印div
的值并用num
除以div
,如果余数不为0
就把div
加1。只要num
大于1,while
循环就一直运行。
当divisors()
函数的传递入参为12
时,它的输出如下所示:
清单2.11的Divisors2.py
也是通过while
循环、条件逻辑和%(取模)运算符来寻找一个大于1的任意整数的因数。
清单2.11 Divisors2.py
清单2.11的代码与清单2.10大部分相同,主要区别是清单2.11在while
循环中构造了变量divList
(它是一串因数的列表),然后在while
循环完成时返回divList
的值。清单2.11的输出如下所示:
2. 通过while
循环寻找素数
清单2.12的Divisor3.py
通过while
循环、条件逻辑和%(取模)运算符来计算一个大于1的任意整数的素数个数。如果一个数只有一个因数(该因数大于1),那么这个数就是一个素数。
清单2.12 Divisor3.py