作业求助
def tongji(*param):'判断传入的参数中英文字母,空格,数字,其他字符的个数'
length = len(param)
for i in range(length):
letters = 0
space = 0
number = 0
other = 0
for each in param:
if each.isalpha():
letters += 1
elif each.isspace():
space += 1
elif each.isdigit():
number += 1
else:
other += 1
print('第%d个字符串共有:%d个英文字母,%d个空格,%d个数字,%d个其他字符'%(i+1,letters,space,number,other))
tongji('1 love y0u~~~','i am better 1314 ### &1')
编写一个函数,分别统计传入字符串参数(可能不止一个参数)的英文字母、空格、数字和其它字符的个数。
i+1是什么意思,怎么实现‘分别’统计,没看懂 本帖最后由 zltzlt 于 2020-8-6 15:44 编辑
由于 i 是从 0 开始的,显示的时候要加一。
怎么实现 “分别” 统计?
遍历每个字符串。
如果遍历到的字符为字母,就将统计字母数量的变量加 1;
如果遍历到的字符为空格,就将统计空格数量的变量加 1;
如果遍历到的字符为数字,就将统计数字数量的变量加 1;
如果遍历到的字符既不是字母、空格,也不是数字,就将统计其他字符的变量加 1。 range如果只有一个参数的话,start是默认为0的,所以i要加1
看看注释吧,解析整个代码哈~希望能帮助到你~:
def count(*param): # 设置传入参数,带 * 号的定义参数表示可以传入不定数量的参数个数 ,并且将所有参数以元组形式保存在 param 中
length = len(param) # 获取参数个数,用于当作循环过程的索引位置参数值,统计各个参数里面的字符个数
for i in range(length): # 循环位置参数
letters = 0 # 初始化字母统计个数
space = 0 # 初始化空格统计个数
digit = 0 # 初始化数字统计个数
others = 0 # 初始化其他字符个数
for each in param: # 循环 i 对应 param 位置参数的字符串字符
if each.isalpha(): # 判断是不是字母,若是统计+1
letters += 1
elif each.isdigit(): # 判断是不是数字,若是统计+1
digit += 1
elif each == ' ': # 判断是不是空格,若是统计+1
space += 1
else: # 若不是数字、字母、空格则算为其他字符,统计+1
others += 1
print('第 %d 个字符串共有:英文字母 %d 个,数字 %d 个,空格 %d 个,其他字符 %d 个。' % (i + 1, letters, digit, space, others))
# 打印本次 for 循环的统计结果,这里 % 是格式化,对应字符串 % 后面的各个变量,替换字符串中的 %d 格式化整型占位符
count('I love fishc.com.', 'I love you, you love me.') for i inrange(5)
i 的返回值分别是
0
1
2
3
4
i+1才能说明是第一个字符串,如果是第0个字符串别人看不懂{:5_91:}大神们,我说的对吗? blackfame 发表于 2020-8-6 15:53
for i inrange(5)
i 的返回值分别是
0
其实这样说百分之50对百分之50不对。
重要的是这个是生活习惯,而不是“看不懂”
页:
[1]