鱼C论坛

 找回密码
 立即注册
查看: 2283|回复: 1

如何检查错误?程序没开循环,运行8次遇到相同的文件就报错

[复制链接]
发表于 2017-6-27 18:00:28 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
编程的主要目的:利用easygui模块,让用户选择代码文件目录,检查每个文件夹下每个文件的代码行数,并累积求和。
编程的主要思路:先利用diropenbox()让用户选择目录,再以二进制的形式打开每个文件并转化成列表,用len计算行数,用字典的形式保存每个后缀名和行数。
整体函数用了递归。但是程序运行错后,只能用idle把递归部分删去检查,发现运行8次,系统就会保错,不太清楚原因。大家有什么好的方法检查程序?


这个整个运行的结果
2.png
def dir_file(catalog):
    while True:
        dir_name = catalog
        catalog_list = os.listdir(dir_name)
        for each in catalog_list:
            if os.path.isfile(each):
                file_name = dir_name + os.sep + each
                file = open(file_name,'rb')
                file_len = len(list(file))
                postfix = each.split('.')
                if postfix[1] not in type_dict:
                    type_dict[postfix[1]] = file_len
                    file_dict[postfix[1]] = 1
                else:
                    type_dict[postfix[1]] += file_len
                    file_dict[postfix[1]] += 1
                file.close()
            else:
                dir_name = dir_name + os.sep + each
                dir_file(dir_name)
        break


import easygui as g
import os
catalog = g.diropenbox('请选择您的代码库','浏览文件夹')
type_dict = {}   #存放文件后缀和行数
file_dict = {}
dir_file(catalog)
dict_msg = type_dict.items()  #导出存放类型行数字典
s_text = []   #存放统计结果的文本内容
all_len = 0   #总行数
for dict_each in dict_msg:
    each_text = '【.%s】源文件%d个,源代码%d行\n'% (dict_each[0],file_dict[dict_each[0]],dict_each[1])
    s_text.append(each_txt)
    all_len += dict_each[1]
plan = str(('%.2f'% ((all_len/100000)*100)))+ '%'
s_msg = '您目前共累积编写了%d行代码,完成进度:%d\n离10万行代码还差%d行,请继续努力!'%(all_len,plan,(100000-all_len))
g.textbox(s_msg,'统计结果',s_txet)



这个是去掉递归的运行和检查图片
1.png

import easygui as g
import os
catalog = g.diropenbox('请选择您的代码库','浏览文件夹')
type_dict = {}   #存放文件后缀和行数
file_dict = {}
dir_name = catalog
catalog_list = os.listdir(dir_name)
for each in catalog_list:
    if os.path.isfile(each):
        file_name = dir_name + os.sep + each
        file = open(file_name,'rb')
        file_len = len(list(file))
        postfix = each.split('.')
        if postfix[1] not in type_dict:
            type_dict[postfix[1]] = file_len
            file_dict[postfix[1]] = 1
        else:
            type_dict[postfix[1]] += file_len
            file_dict[postfix[1]] += 1
    else:
        dir_name = dir_name + os.sep + each
        
        
dict_msg = type_dict.items()  #导出存放类型行数字典

s_text = []   #存放统计结果的文本内容
all_len = 0   #总行数
for dict_each in dict_msg:
    each_text = '【.%s】源文件%d个,源代码%d行\n'% (dict_each[0],file_dict[dict_each[0]],dict_each[1])
    s_text.append(each_txt)
    all_len += dict_each[1]
plan = str(('%.2f'% ((all_len/100000)*100)))+ '%'
s_msg = '您目前共累积编写了%d行代码,完成进度:%d\n离10万行代码还差%d行,请继续努力!'%(all_len,plan,(100000-all_len))
g.textbox(s_msg,'统计结果',s_txet)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-6-18 22:27:09 | 显示全部楼层
拼写错误太多了,不一一举例了
def dir_file(catalog):
    
        dir_name = catalog
        os.chdir(dir_name)
        catalog_list = os.listdir(dir_name)
        for each in catalog_list:
            if os.path.isfile(each):
                file_name = dir_name + os.sep + each
                file = open(file_name,'rb')
                file_len = len(list(file))
                postfix = each.split('.')
                if postfix[1] not in type_dict:
                    type_dict[postfix[1]] = file_len
                    file_dict[postfix[1]] = 1
                else:
                    type_dict[postfix[1]] += file_len
                    file_dict[postfix[1]] += 1
                file.close()
            else:
                file_name2 = dir_name + os.sep + each
                dir_file(file_name2)
                os.chdir(os.pardir)
       


import easygui as g
import os
catalog = g.diropenbox('请选择您的代码库','浏览文件夹')
type_dict = {}   #存放文件后缀和行数
file_dict = {}
dir_file(catalog)
dict_msg = type_dict.items()  #导出存放类型行数字典
s_text = []   #存放统计结果的文本内容
all_len = 0   #总行数
for dict_each in dict_msg:
    each_text = '【.%s】源文件%d个,源代码%d行\n'% (dict_each[0],file_dict[dict_each[0]],dict_each[1])
    s_text.append(each_text)
    all_len += dict_each[1]
plan =str(('%.2f'% ((all_len/100000)*100)))+ '%'
s_msg = '您目前共累积编写了%d行代码,完成进度:%s\n离10万行代码还差%d行,请继续努力!'%(all_len,plan,(100000-all_len))
g.textbox(s_msg,'统计结果',s_text)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-2-22 02:33

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表