鱼C论坛

 找回密码
 立即注册
查看: 1440|回复: 5

[已解决]新人求教,《零基础入门学习Python》第35课最后一题问题

[复制链接]
发表于 2018-4-13 21:36:44 | 显示全部楼层 |阅读模式

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

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

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.     for each_file in os.listdir(os.curdir):  #os.curdir当前目录,os.listdir列举目录中文件名
  27.         ext = os.path.splitext(each_file)[1]  #分离文件与扩展名,ext储存扩展名
  28.         if ext in target:
  29.             lines = calc_code(each_file)  #统计行数
  30.             #统计文件数
  31.             try:
  32.                 file_list[ext] += 1
  33.             except KeyError:
  34.                 file_list[ext] = 1

  35.             #统计源代码行数
  36.             try:
  37.                 source_list[ext]+= lines
  38.             except KeyError:
  39.                 source_list[ext] = lines

  40.         if os.path.isdir(each_file):  #判断是否存在目录os.path.isdir
  41.             search_file(each_file) #递归调用
  42.             os.chdir(os.pardir)#递归调用后切记返回上一层目录,os.pardir指代上级目录

  43. target = ['.c','.ccp','.py',',cc','.java','.pas','.asm']
  44. file_list ={ }
  45. source_list = { }

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

  48. search_file(path)
  49. show_result(path)
  50.                
复制代码


这个题我自己统计出来的结果显示源代码行数为0,这是为什么?
捕获.PNG
最佳答案
2018-4-14 12:43:36
我个人感觉是因为cacl模块中的except UnicodeDecodeError 这里的本意是无视那些无法识别的编码的文件,但是你的代码文件也是用gbk编码的,导致他直接无视了,所以显示代码是0行。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-4-14 09:18:21 | 显示全部楼层
求教啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-14 12:43:36 | 显示全部楼层    本楼为最佳答案   
我个人感觉是因为cacl模块中的except UnicodeDecodeError 这里的本意是无视那些无法识别的编码的文件,但是你的代码文件也是用gbk编码的,导致他直接无视了,所以显示代码是0行。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-4-14 13:39:43 | 显示全部楼层
Luke李 发表于 2018-4-14 12:43
我个人感觉是因为cacl模块中的except UnicodeDecodeError 这里的本意是无视那些无法识别的编码的文件,但是 ...

谢谢,应该是这样的,那请问怎么才能改一下让他可以读出来呢?你知道么
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-14 13:52:27 | 显示全部楼层
e
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-4-14 17:37:52 | 显示全部楼层
本帖最后由 Luke李 于 2018-4-14 17:39 编辑
wj465596344 发表于 2018-4-14 13:39
谢谢,应该是这样的,那请问怎么才能改一下让他可以读出来呢?你知道么



你可以把calc里面的with那句改成:   with open(file_name, encoding= 'utf-8') as f:
这样在打开文件时默认编码方式utf-8,应该就没问题了

评分

参与人数 1鱼币 +1 收起 理由
wj465596344 + 1 感谢楼主无私奉献!

查看全部评分

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

使用道具 举报

 楼主| 发表于 2018-4-15 09:05:18 | 显示全部楼层
Luke李 发表于 2018-4-14 17:37
你可以把calc里面的with那句改成:   with open(file_name, encoding= 'utf-8') as f:
这样在打开文 ...

谢谢,这样就可以了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-10 13:20

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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