怎么理解Python中的for循环

寻技术 Python编程 2023年09月27日 75

本文小编为大家详细介绍“怎么理解Python中的for循环”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么理解Python中的for循环”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

01 使用tryexcept的for循环

清单1 的StringToNums.py说明了如何对一组从字符串转换而来的整数求和。

  • 清单1 StringToNums.py

line = '1 2 3 4 10e abc'  sum  = 0  invalidStr = ""  print('String of numbers:',line)  for str in line.split(" "):    try:     sumsum = sum + eval(str)    except:      invalidStrinvalidStr = invalidStr + str + ' '  print('sum:', sum)  if(invalidStr != ""):    print('Invalid strings:',invalidStr) else:    print('All substrings are valid numbers')

清单1 首先初始化变量line、sum和invalidStr,然后显示line的内容。接下来将line中的内容分割为单词,然后通过try代码块逐个将单词的数值累加到变量sum 中。如果发生异常,则将当前str的内容追加到变量invalidStr。

当循环执行结束,清单1 打印出数值单词的和,并在后面显示非数值单词。

02 指数运算

清单2 的Nth_exponet.py说明了如何计算一组整数的幂。

  • 清单2 Nth_exponet.py

maxPower = 4  maxCount = 4  def pwr(num):    prod = 1    for n in range(1,maxPower+1):      prodprod = prod*num      print(num,'to the power',n, 'equals',prod)    print('-----------')  for num in range(1,maxCount+1):      pwr(num)

清单2 中有一个pwr()函数,其参数为一个数值。此函数中的循环可打印出参数的1 到n次方,n的取值范围在1到maxCount+1之间。

代码的第二部分通过一个for循环调用pwr()函数从1到maxCount+1的值。

03 嵌套的循环

清单3 的Triangular1.py说明了如何打印一行连续整数(从1开始),其中每一行的长度都比前一行大1。

  • 清单3 Triangular1.py

max = 8  for x in range(1,max+1):    for y in range(1,x+1):      print(y,'', end='')    print()

清单3 首先初始化max变量为8,之后通过变量x从1到max+1执行循环。内层循环有一个值为从1到x+1的循环变量y,并打印y的值。

04 在for循环中使用split()函数

Python 支持各种便捷的字符串操作相关函数,包括split()函数和join()函数。在需要将一行文本分词化(即“分割”)为单词,然后使用for循环遍历这些单词时,split()函数非常有用。

join()函数与split()函数相反,它将两个或多个单词“连接”为一行。通过使用split()函数,你可以轻松地删除句子中多余的空格,然后调用join()函数,使文本行中每个单词之间只有一个空格。

1. 使用split()函数做单词比较

清单4 的Compare2.py说明了如何通过split()函数将文本字符串中的每个单词与另一个单词进行比较。

  • 清单4 Compare2.py

x = 'This is a string that contains abc and Abc'  y = 'abc'  identical = 0  casematch = 0  for w in x.split():    if(w == y):      identicalidentical = identical + 1    elif (w.lower() == y.lower()):      casematchcasematch = casematch + 1  if(identical > 0):   print('found identical matches:', identical)  if(casematch > 0):   print('found case matches:', casematch)  if(casematch == 0 and identical == 0):   print('no matches found')

清单4 通过split()函数对字符串x中的每个单词与单词abc进行比较。如果单词精确匹配,就将identical变量加1 ;否则就尝试不区分大小写进行比较,若匹配就将casematch变量加1。

2. 使用split()函数打印指定格式的文本

清单5 的FixedColumnCount1.py 说明了如何打印一组设定固定宽度的字符串。

  • 清单5 FixedColumnCount1.py

import string  wordCount = 0  str1 = 'this is a string with a set of words in it'  print('Left-justified strings:')  print('-----------------------')  for w in str1.split():     print('%-10s' % w)     wordCountwordCount = wordCount + 1     if(wordCount % 2 == 0):        print("")  print("n")  print('Right-justified strings:')   print('------------------------')   wordCount = 0  for w in str1.split():     print('%10s' % w)     wordCountwordCount = wordCount + 1     if(wordCount % 2 == 0):        print()

清单5 首先初始化变量wordCount和str1,然后执行两个for循环。第一个for 循环对str1的每个单词进行左对齐打印,第二个for循环对str1的每个单词进行右对齐打印。在每个循环中当wordCount是偶数的时候就输出一次换行,这样每打印两个连续的单词之后就换行。

3. 使用split()函数打印固定宽度的文本

清单6 的FixedColumnWidth2.py说明了如何打印固定宽度的文本。

  • 清单6 FixedColumnWidth2.py

import string  left = 0  right = 0  columnWidth = 8  str1 = 'this is a string with a set of words in it and it will be split into a fixed column width'  strLen = len(str1)  print('Left-justified column:')   print('----------------------')   rowCount = int(strLen/columnWidth)  for i in range(0,rowCount):     left  = i*columnWidth     right = (i+1)*columnWidth-1     word  = str1[left:right]     print("%-10s" % word)  # check for a 'partial row'  if(rowCount*columnWidth < strLen):     left  = rowCount*columnWidth-1;     right = strLen     word  = str1[left:right]     print("%-10s" % word)

清单6 初始化整型变量columnWidth和字符串类型变量str1。变量strLen是str1的长度,变量rowCount是strLen除以columnWidth的值。之后通过循环打印rowCount行,每行包含columnWidth个字符。代码的最后部分输出所有“剩余”的字符。

4. 使用split()函数比较文本字符串

清单7 的CompareStrings1.py说明了如何判断一个文本字符串中的单词是否出现在另一个文本字符串中。

  • 清单7 CompareStrings1.py

text1 = 'a b c d'  text2 = 'a b c e d'  if(text2.find(text1) >= 0):    print('text1 is a substring of text2') else:    print('text1 is not a substring of text2')  subStr = True for w in text1.split():    if(text2.find(w) == -1):      subStr = False      break  if(subStr == True):    print('Every word in text1 is a word in text2')  else:    print('Not every word in text1 is a word in text2')

清单7 首先初始化两个字符串变量text1和text2,然后通过条件逻辑判断字符串text2是否包含了text1(并输出相应打印信息)。

清单7 的后半部分通过一个循环遍历字符串text1中的每个单词,并判断其是否出现在text2中。如果发现有匹配失败的情况,就设置变量subStr为False,并通过break语句跳出循环,提前终止for循环的执行。最后根据变量subStr的值打印对应的信息。

05 用基础的for循环显示字符串中的字符

清单8 的StringChars1.py说明了如何打印一个文本字符串中的字符。

  • 清单8 StringChars1.py

text = 'abcdef'  for ch in text:     print('char:',ch,'ord value:',ord(ch)) print

清单8 的代码简单直接地通过一个for循环遍历字符串text并打印它的每个字符以及字符的ord值(ASCII 码)。

06 join()函数

另一个去掉多余空格的方法是使用join()函数

split()函数将一个文本字符串“分割”为一系列的单词,同时去掉多余的空格。接下来join()函数使用一个空格作为分隔符将字符串text1中的单词连接在一起。上述代码的最后部分使用字符串XYZ替换空格作为分隔符,执行相同的连接操作。

关闭

用微信“扫一扫”