鱼C论坛

 找回密码
 立即注册
查看: 1366|回复: 2

[已解决]课后作业 有个地方没懂 望指教

[复制链接]
发表于 2017-12-9 21:27:48 | 显示全部楼层 |阅读模式

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

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

x
  1. import easygui as g
  2. import os

  3. def show_result(start_dir):
  4.     lines = 0
  5.     total = 0
  6.     text = ""

  7.     for i in source_list:
  8.         lines = source_list[i]
  9.         total += lines
  10.         text += "【%s】源文件 %d 个,源代码 %d 行\n" % (i, file_list[i], lines)
  11.     title = '统计结果'
  12.     msg = '您目前共累积编写了 %d 行代码,完成进度:%.2f %%\n离 10 万行代码还差 %d 行,请继续努力!' % (total, total/1000, 100000-total)
  13.     g.textbox(msg, title, text)

  14. def calc_code(file_name):
  15.     lines = 0
  16.     with open(file_name) as f:
  17.         print('正在分析文件:%s ...' % file_name)
  18.         try:
  19.             for each_line in f:
  20.                 lines += 1
  21.         except UnicodeDecodeError:
  22.             pass # 不可避免会遇到格式不兼容的文件,这里忽略掉......
  23.     return lines

  24. def search_file(start_dir) :
  25.     os.chdir(start_dir)
  26.    
  27.     for each_file in os.listdir(os.curdir) :
  28.         ext = os.path.splitext(each_file)[1]
  29.         if ext in target :
  30.             lines = calc_code(each_file) # 统计行数
  31.             # 还记得异常的用法吗?如果字典中不存,抛出 KeyError,则添加字典键
  32.             # 统计文件数
  33.             try:
  34.                 file_list[ext] += 1
  35.             except KeyError:
  36.                 file_list[ext] = 1
  37.             # 统计源代码行数
  38.             try:
  39.                 source_list[ext] += lines
  40.             except KeyError:
  41.                 source_list[ext] = lines
  42.             
  43.         if os.path.isdir(each_file) :
  44.             search_file(each_file) # 递归调用
  45.             os.chdir(os.pardir) # 递归调用后切记返回上一层目录
  46.             
  47. target = ['.c', '.cpp', '.py', '.cc', '.java', '.pas', '.asm']
  48. file_list = {}
  49. source_list = {}

  50. g.msgbox("请打开您存放所有代码的文件夹......", "统计代码量")
  51. path = g.diropenbox("请选择您的代码库:")

  52. search_file(path)
  53. show_result(path)
复制代码

是怎么统计行数的没看懂
为什么递归要返回上一次目录
最佳答案
2017-12-9 22:34:31
第一个问题,怎么统计行数的
代码第33行开始,到45行:如果遇到的是一个文件,并且扩展名在 target 列表里面
    调用 calc_code()函数,参数就是文件的路径(转到代码第17行)
        然后,calc_cod3()函数会打开这个文件
            for 循环每次读取一行 lines += 1 (并用异常处理机制过滤编码不兼容的文件),
                return lines(获得了一个文件的总行数)

第二个问题:为什么递归要返回上一级目录
在当前文件夹下搜索文件,如果是遇到目录1就会递归调用自身进行文件搜索,搜索完成后就要返回到父级目录,不然,万一之前的文件夹下还有其他文件夹,那么就无法遍历所有文件。所以必须返回,没有商量的余地。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-12-9 21:33:29 From FishC Mobile | 显示全部楼层
为了实现同一文件夹下不同文件夹里有目标文件需要统计
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-12-9 22:34:31 | 显示全部楼层    本楼为最佳答案   
第一个问题,怎么统计行数的
代码第33行开始,到45行:如果遇到的是一个文件,并且扩展名在 target 列表里面
    调用 calc_code()函数,参数就是文件的路径(转到代码第17行)
        然后,calc_cod3()函数会打开这个文件
            for 循环每次读取一行 lines += 1 (并用异常处理机制过滤编码不兼容的文件),
                return lines(获得了一个文件的总行数)

第二个问题:为什么递归要返回上一级目录
在当前文件夹下搜索文件,如果是遇到目录1就会递归调用自身进行文件搜索,搜索完成后就要返回到父级目录,不然,万一之前的文件夹下还有其他文件夹,那么就无法遍历所有文件。所以必须返回,没有商量的余地。

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
792136506 + 5 + 5 + 3 懂了懂了,谢了

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 13:13

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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