for ... in range()到底怎么用
为什么第一个range的范围就是for each1 in range(length-1)“length-1”;第二个range的范围就是for i in range(length)“length”?????1. 编写一个函数 findstr(),该函数统计一个长度为 2 的子字符串在另一个字符串中出现的次数。例如:假定输入的字符串为“You cannot improve your past, but you can improve your future. Once time is wasted, life is wasted.”,子字符串为“im”,函数执行后打印“子字母串在目标字符串中共出现 3 次”。
def findStr(desStr, subStr):
count = 0
length = len(desStr)
if subStr not in desStr:
print('在目标字符串中未找到字符串!')
else:
for each1 in range(length-1):
if desStr == subStr:
if desStr == subStr:
count += 1
print('子字符串在目标字符串中共出现 %d 次' % count)
desStr = input('请输入目标字符串:')
subStr = input('请输入子字符串(两个字符):')
findStr(desStr, subStr)
复制代码
2. 编写一个函数,分别统计出传入字符串参数(可能不只一个参数)的英文字母、空格、数字和其它字符的个数。
def count(*param):
length = len(param)
for i in range(length):
letters = 0
space = 0
digit = 0
others = 0
for each in param:
if each.isalpha():
letters += 1
elif each.isdigit():
digit += 1
elif each == ' ':
space += 1
else:
others += 1
print('第 %d 个字符串共有:英文字母 %d 个,数字 %d 个,空格 %d 个,其他字符 %d 个。' % (i+1, letters, digit, space, others))
count('I love fishc.com.', 'I love you, you love me.')
复制代码
本帖最后由 jackz007 于 2020-12-14 00:15 编辑
在第一题中
def findStr(desStr, subStr):
. . . . . .
length = len(desStr)
. . . . . .
for each1 in range(length-1):
. . . . . .
if desStr == subStr:
在这个代码中,length 是字符串 desStr 的长度,也就是字符串中的字符个数,那么,通过切片访问字符串的第一个元素是 desStr,最后一个元素是 desStr,range(length) 会从 0 开始,以步长 1 产生一些列整型数,其中,最后一个整数是 length - 2, 在 for 循环中有这条语句:
if desStr == subStr:
对于 desStr 而言,最后一次循环 each1 = length - 2,那么, desStr = desStr =desStr恰好可以切片到字符串的最后一个字符,如果在 for 循环中范围使用的是 range(length) ,那么,不难预见,最后一次循环 desStr= desStr = desStr 显然会引起字符串下标索引越界错误。
在第二题中
def count(*param):
length = len(param)
for i in range(length):
. . . . . .
for each in param:
length 是输入可变参数 param 中所包含的元素个数,在本例中 length = 2
for i in range(length):
循环变量将陆续等于 0 , 1。那么,通过后面的循环,通过 param 和 param 就可以做到对输入参数 param 中 2 个参数的遍历和访问。
总结一下,第一题因为需要在循环中每次访问、比较目标对象的 2 个元素,所以,循环变量的变化范围要使用 range(length - 1) 来界定,第二题每次循环只需要遍历、访问目标对象的一个元素,所以, 循环变量的变化范围使用 range(length) 就可以界定。 帮顶下{:10_256:}
页:
[1]