鱼C论坛

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

[已解决]35课统计自己写的代码量

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

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

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

x
代码看了很多遍,一直出错,求帮助,谢谢!
代码:
  1. import os

  2. def search(dir):
  3.     list = os.listdir(os.curdir)
  4.     for each in list:
  5.         if each.split('.')[1] == 'py':
  6.             lines = calc_code(each)

  7. def calc_code(file):
  8.     lines = 0
  9.     with open(file) as f:
  10.         print('正在分析文件:%s ...' % file)
  11.         for each_line in f:
  12.             lines += 1
  13.     return lines

  14. search(dir)
复制代码

报错原因:
  1. Traceback (most recent call last):
  2.   File "E:\python 3.6.1\exercise\1-9课\35e统计自己写的代码行数.py", line 20, in <module>
  3.     search(dir)
  4.   File "E:\python 3.6.1\exercise\1-9课\35e统计自己写的代码行数.py", line 10, in search
  5.     lines = calc_code(each)
  6.   File "E:\python 3.6.1\exercise\1-9课\35e统计自己写的代码行数.py", line 16, in calc_code
  7.     for each_line in f:
  8. UnicodeDecodeError: 'gbk' codec can't decode byte 0xa0 in position 66: illegal multibyte sequence
复制代码
最佳答案
2017-9-21 17:51:07
先试试这个,再不行,用下面的
  1. import os

  2. def search(dir):
  3.     list = os.listdir(os.curdir)
  4.     for each in list:
  5.         if each.split('.')[1] == 'py':
  6.             lines = calc_code(each)

  7. def calc_code(file):
  8.     lines = 0
  9.     with open(file, encoding = 'gbk') as f:
  10.         print('正在分析文件:%s ...' % file)
  11.         for each_line in f:
  12.             lines += 1
  13.     return lines

  14. search(dir)
复制代码

这个是备用
  1. import os

  2. def search(dir):
  3.     list = os.listdir(os.curdir)
  4.     for each in list:
  5.         if each.split('.')[1] == 'py':
  6.             lines = calc_code(each)

  7. def calc_code(file):
  8.     lines = 0
  9.     with open(file, encoding = 'utf-8') as f:
  10.         print('正在分析文件:%s ...' % file)
  11.         for each_line in f:
  12.             lines += 1
  13.     return lines

  14. search(dir)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-9-21 17:51:07 | 显示全部楼层    本楼为最佳答案   
先试试这个,再不行,用下面的
  1. import os

  2. def search(dir):
  3.     list = os.listdir(os.curdir)
  4.     for each in list:
  5.         if each.split('.')[1] == 'py':
  6.             lines = calc_code(each)

  7. def calc_code(file):
  8.     lines = 0
  9.     with open(file, encoding = 'gbk') as f:
  10.         print('正在分析文件:%s ...' % file)
  11.         for each_line in f:
  12.             lines += 1
  13.     return lines

  14. search(dir)
复制代码

这个是备用
  1. import os

  2. def search(dir):
  3.     list = os.listdir(os.curdir)
  4.     for each in list:
  5.         if each.split('.')[1] == 'py':
  6.             lines = calc_code(each)

  7. def calc_code(file):
  8.     lines = 0
  9.     with open(file, encoding = 'utf-8') as f:
  10.         print('正在分析文件:%s ...' % file)
  11.         for each_line in f:
  12.             lines += 1
  13.     return lines

  14. search(dir)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-9-22 08:52:16 | 显示全部楼层
新手·ing 发表于 2017-9-21 17:51
先试试这个,再不行,用下面的

这个是备用

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

使用道具 举报

 楼主| 发表于 2017-9-22 09:49:44 | 显示全部楼层
新手·ing 发表于 2017-9-21 17:51
先试试这个,再不行,用下面的

这个是备用

再请教一个问题,这个代码我想返回总的lines,应该如何操作?
  1. import os

  2. def search():
  3.     list = os.listdir(os.curdir)
  4.     for each in list:
  5.         if each.split('.')[1] == 'py':
  6.             lines = calc_code(each)

  7. def calc_code(file):
  8.     lines = 0
  9.     with open(file, encoding = 'utf-8') as f:
  10.         print('正在分析文件:%s ...' % file)
  11.         for each_line in f:
  12.             lines += 1
  13.     return lines

  14. num = search()
  15. print(num)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-9-22 18:01:40 | 显示全部楼层
sige 发表于 2017-9-22 09:49
再请教一个问题,这个代码我想返回总的lines,应该如何操作?

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

使用道具 举报

 楼主| 发表于 2017-9-23 19:02:40 | 显示全部楼层

虽然这个代码最后return的是line,但运行之后返回的是none,而不是我想返回的line(总次数)
  1. import os

  2. def search():
  3.     list = os.listdir(os.curdir)
  4.     for each in list:
  5.         if each.split('.')[1] == 'py':
  6.             lines = calc_code(each)

  7. def calc_code(file):
  8.     lines = 0
  9.     with open(file, encoding = 'utf-8') as f:
  10.         print('正在分析文件:%s ...' % file)
  11.         for each_line in f:
  12.             lines += 1
  13.     return lines

  14. num = search()
  15. print(num)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-3-19 18:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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