|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 easyboy 于 2021-6-3 21:08 编辑
0. 请用已学过的知识编写程序,统计下边这个长字符串中各个字符出现的次数并找到小甲鱼送给大家的一句话。
(由于我们还没有学习到文件读取方法,大家下载后拷贝过去即可)
temp = open(r'C:\Users\Indifferece\Desktop\string1\string1.txt')
str1 = temp.read()
list1 = []
for each in str1:
if each not in list1:
if each == '\n':
print('\\n', str1.count(each))
else:
print(each, str1.count(each))
list1.append(each)
for each in str1:
if each.isalpha():
print(each,end='')
print()
print(list1)
下面是运行结果
======================= RESTART: C:\Users\Indifferece\Desktop\p14_1.py =======================
% 6104
$ 6046
@ 6157
_ 6112
^ 6030
# 6115
) 6186
& 6043
! 6079
+ 6066
] 6152
* 6034
} 6105
[ 6108
( 6154
{ 6046
\n 1219
G 1
O 2
D 1
L 1
U 1
C 1
K 1
GOODLUCK
['%', '$', '@', '_', '^', '#', ')', '&', '!', '+', ']', '*', '}', '[', '(', '{', '\n', 'G', 'O', 'D', 'L', 'U', 'C', 'K']
为什么list1内为什么不是全部的str1内容?
最好能在每一段代码后面加注释解释代码运行逻辑
[b]
for 循环下的第一个 if 条件先判断了该字符是否加入 list1 了,只有未加入的才执行 if 内的代码块
所以 for 循环每个不同字符只要一循环到,就会被加入 list1 列表中
下次循环若遇到相同字符,if each not in list1 条件不通过,就不会将这次的字符再次加入列表 list
所以只有每种字符的一个
看代码注释:
temp = open(r'C:\Users\Indifferece\Desktop\string1\string1.txt')
str1 = temp.read()
list1 = []
for each in str1:
# for 循环遍历每一个字符
if each not in list1:
# if 判断字符是否在 list1 列表中,若在列表中则不符合 if 条件,不进入 if 代码块
if each == '\n':
# 判断 each 是否为换行符,若是执行 if 代码块,否则执行 else
# 因为这里的 换行符 \n 需要单独进行转义才能将 \n 打印出来
# 否则若不进行 \\ 转义就会打印一个空行
print('\\n', str1.count(each))
else:
print(each, str1.count(each))
list1.append(each)
# 将本次循环到的字符加入 list1 列表,下次再次循环到就不进行重复打印
# 即这里前面 for 循环下的 第一个 if 作用,避免重复打印
for each in str1:
# 这里代码是为了打印出列表中为字母的字符串
if each.isalpha():
# isalpha 函数判断是否为全为字母字符,若是就执行 if 代码块
print(each,end='')
print()
# 这里 print() 起到换行作用,end 默认参数值为 '\n' 换行符
print(list1)
# 打印字符列表
[/b]
|
|