鱼C论坛

 找回密码
 立即注册
查看: 984|回复: 6

[已解决]第35讲 统计当前代码量总和

[复制链接]
发表于 2020-5-3 16:41:23 | 显示全部楼层 |阅读模式

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

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

x
我在做第35讲 统计当前代码量总和时,发现我的文件都无法被识别代码量,想弄清楚原因
运行的就是小甲鱼老师的代码
在calc_code(file_name)时,每次都会跳转到except UnicodeDecodeError
文件里面放的代码就是平常做作业写的代码,是有内容的,为什么就不兼容了呢
  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.             print('不兼容')
  23.             pass # 不可避免会遇到格式不兼容的文件,这里忽略掉......
  24.     return lines

  25. def search_file(start_dir) :
  26.     os.chdir(start_dir)
  27.    
  28.     for each_file in os.listdir(os.curdir) :
  29.         ext = os.path.splitext(each_file)[1]
  30.         if ext in target :
  31.             lines = calc_code(each_file) # 统计行数
  32.             # 还记得异常的用法吗?如果字典中不存,抛出 KeyError,则添加字典键
  33.             # 统计文件数

  34.             try:
  35.                 file_list[ext] += 1
  36.             except KeyError:
  37.                 file_list[ext] = 1
  38.             # 统计源代码行数
  39.             try:
  40.                 source_list[ext] += lines
  41.             except KeyError:
  42.                 source_list[ext] = lines
  43.             
  44.         if os.path.isdir(each_file) :
  45.             search_file(each_file) # 递归调用
  46.             os.chdir(os.pardir) # 递归调用后切记返回上一层目录
  47.             
  48. target = ['.c', '.cpp', '.py', '.cc', '.java', '.pas', '.asm']
  49. file_list = {}
  50. source_list = {}

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

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

最佳答案
2020-5-4 12:20:25

有很多方法
用记事本打开,另存为,然后看右下角的编码
或者用notepad++,vscode之类的编辑器,都会在右下角显示文件编码,很方便
1.PNG
2.PNG
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-5-3 18:02:17 | 显示全部楼层
看看那些py文件的编码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-4 11:53:29 | 显示全部楼层
_荟桐_ 发表于 2020-5-3 18:02
看看那些py文件的编码

怎么看编码?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-4 12:20:25 | 显示全部楼层    本楼为最佳答案   

有很多方法
用记事本打开,另存为,然后看右下角的编码
或者用notepad++,vscode之类的编辑器,都会在右下角显示文件编码,很方便

评分

参与人数 1鱼币 +1 收起 理由
永恒的蓝色梦想 + 1 无条件支持楼主!

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-4 12:23:15 | 显示全部楼层
把那一段改成这样,看看打印了什么
  1. except UnicodeDecodeError as asdf:
  2.             print('不兼容')
  3.             print(asdf)
  4.             pass # 不可避免会遇到格式不兼容的文件,这里忽略掉......
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-12 20:40:03 | 显示全部楼层
我也有这个问题,好多文件都不兼容呀
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-12 21:36:04 | 显示全部楼层
没有考虑注释,和空行;
对于c这种编码风格灵活的,大括号换行应该不算;
可以学习 cloc 的源码,虽然是 perl 的。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-19 08:25

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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