|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- def count(*param):
- length = len(param)
- for i in range(length):
- letters = 0
- space = 0
- digit = 0
- others = 0
- for each in param[i]:
- 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))
复制代码
最后输出的这个i+1是什么意思?
因为索引是从 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]: # 循环 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))
- # 因为索引是从 0 开始的,而我们一般称为第一个字符,所以这里 i + 1
- # 打印本次 for 循环的统计结果,这里 % 是格式化,对应字符串 % 后面的各个变量,替换字符串中的 %d 格式化整型占位符
- count('I love fishc.com.', 'I love you, Python!')
复制代码
|
|