关于第35将讲最后一题,求助大佬jieda
# 4. 写一个程序统计你当前代码量的总和,并显示离十万行代码量还有多远?#
# 要求一:递归搜索各个文件夹
# 要求二:显示各个类型的源文件和源代码数量(先用字典简单显示)
# 要求三:显示总行数与百分比 (还没做到)
#coding=utf-8
import os
import easygui as g
temp_set = set()
temp_list = []
memory_dict = dict()
sum_line = 0
def count_code():
global sum_line
global memory_dict
path = g.diropenbox()
os.chdir(path)
for each_file in os.listdir(os.curdir):
temp_set.add(os.path.splitext(each_file))
# temp_set = ['.txt', '.py']
for dif_type in temp_set:
sum_line = 0
if os.path.splitext(each_file) == dif_type:
try:
with open(str(each_file), 'r', encoding='utf-8') as f:
f_list = list(f)
sum_line = len(f_list)
temp_list.append(sum_line)#应该是问题所在?T_T
memory_dict = temp_list
except UnicodeDecodeError:
pass
if os.path.isdir(each_file):
count_code(each_file)
os.chdir(os.pardir)
print(memory_dict)
count_code()
结果出来之后,发现行数会重复计算,想了好久没想到解决办法,有大佬可以指点一下吗?
结果:{'.py': , '.txt': } 楼主 你已经知道问题所在了呀,我看那里就是问题,所以我给改了一下,把你注释问题所在的那行改成:
temp_list = memory_dict.get(dif_type, 0) + sum_line 弱弱的佳佳 发表于 2020-10-5 20:16
楼主 你已经知道问题所在了呀,我看那里就是问题,所以我给改了一下,把你注释问题所在的那行改成:
temp_ ...
厉害呀!谢谢!{:10_254:} 弱弱的佳佳 发表于 2020-10-5 20:16
楼主 你已经知道问题所在了呀,我看那里就是问题,所以我给改了一下,把你注释问题所在的那行改成:
temp_ ...
想再请教一下,dict.get(key, 0)这里的0的意思是什么呢? 我去掉之后,会提示类型相加错误,看过帮助文档没有找到对应的地方~ shuishuishui uranometria 发表于 2020-10-5 22:50
想再请教一下,dict.get(key, 0)这里的0的意思是什么呢? 我去掉之后,会提示类型相加错误,看过帮助文档 ...
这个是从字典里面取值,字典里是key:value的形式,如果在字典里有key,就能取到对应的value,如果字典里没有这个key就取到0! 弱弱的佳佳 发表于 2020-10-6 08:32
这个是从字典里面取值,字典里是key:value的形式,如果在字典里有key,就能取到对应的value,如果字典里 ...
好的谢谢!明白鸟~
页:
[1]