零基础Python 第十八讲 不明白
for each1 in range(length-1): 这里为什么要把获取的字符长度减一2. 编写一个函数 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)
复制代码 range 是从0开始的,你字符串如果长度是10,那么应该是0-9,即range(0,9),因为0是默认的,可以省略 灰晨 发表于 2021-6-1 14:33
range 是从0开始的,你字符串如果长度是10,那么应该是0-9,即range(0,9),因为0是默认的,可以省略
那为什么要range已经是0-9了在减一不就0-8少一个了吗 路人乙宝 发表于 2021-6-1 15:03
那为什么要range已经是0-9了在减一不就0-8少一个了吗
。。我的意思是你 length = len(desStr) 这个长度是10,所有要减1,range(0,9) 本帖最后由 路人乙宝 于 2021-6-1 15:30 编辑
灰晨 发表于 2021-6-1 15:05
。。我的意思是你 length = len(desStr) 这个长度是10,所有要减1,range(0,9)
length = len(desStr) 这个长度是10,但后面range(length)获取的 0-9正好十个 减一的话0-8不就少了一个吗 本帖最后由 灰晨 于 2021-6-1 15:52 编辑
路人乙宝 发表于 2021-6-1 15:29
length = len(desStr) 这个长度是10,但后面range(length)获取的 0-9正好十个 减一的话0-8不就 ...
。。。。。。length = len(desStr) 这个长度是10,后面range(length)就是range(10)啊,它会获取0-10的,所以要减1啊{:10_247:}
因为你 for 循环中 第二个 if 中是 desStr
而切片索引最长长度为字符串长度,即 length 变量
而你 for 循环中若不进行 -1 ,那么就会导致 each1 + 1 循环时超出字符串最大索引值导致报错
所以需要在 range 内进行 -1 楼上正解!!
页:
[1]