求助18讲的一个题
编写一个函数 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)
麻烦大佬们解释一下啊 这是格式化字符串啊
就是把%后面的变量替换
前面写的格式化操作符
lz都学到这里了,这个还不会,
你再重头学一遍吧 就是简单的格式化字符串,把count的内容赋给前面的%d.. 这是格式化字符串,字符串中的 %d 表示占位符,用于格式化整数,将后面的 count 填充到 %d 那里。
如果忘记了如何格式化字符串,可以去复习复习:https://www.bilibili.com/video/BV1Fs411A7HZ?p=16 qiuyouzhi 发表于 2020-4-14 09:43
这是格式化字符串啊
就是把%后面的变量替换
前面写的格式化操作符
不是 我不会的是中间的那一段
for each1 in range(length-1):
if desStr == subStr:
if desStr == subStr:
count +=1
这个
为什么第一段里面是range(length-1)而不是length qiuyouzhi 发表于 2020-4-14 09:43
这是格式化字符串啊
就是把%后面的变量替换
前面写的格式化操作符
你这话咋这么酸呢 不会不该问吗 Lousy 发表于 2020-4-14 16:45
你这话咋这么酸呢 不会不该问吗
哎呀 不好意思我把你看成一层的家伙了 qiuyouzhi 发表于 2020-4-14 09:43
这是格式化字符串啊
就是把%后面的变量替换
前面写的格式化操作符
我是不懂这个
for each1 in range(length-1):
if desStr == subStr:
if desStr == subStr:
count +=1
为什么是range(length-1) Lousy 发表于 2020-4-14 16:46
哎呀 不好意思我把你看成一层的家伙了
?????一层的是你自己 永恒的蓝色梦想 发表于 2020-4-14 17:07
?????一层的是你自己
不对不对 是二层 Lousy 发表于 2020-4-14 19:21
不对不对 是二层
你连着回了二楼三次,我都不知道你想说什么 字符串的角标是从0开始的,打个比方来说,str=‘abc’,这个字符串的长度是3,但是取值的时候,你取的只能是str,str,str,而没有str,因为越界了 岚冰1234 发表于 2020-4-15 01:51
字符串的角标是从0开始的,打个比方来说,str=‘abc’,这个字符串的长度是3,但是取值的时候,你取的只能 ...
哎呀一下明白了 谢谢大佬
页:
[1]