鱼C论坛

 找回密码
 立即注册
查看: 1618|回复: 10

[已解决]课后作业~~35

[复制链接]
发表于 2020-7-22 10:29:27 | 显示全部楼层 |阅读模式

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

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

x
9GHYR~E[YARC4LW`2U9N262.png
如图,1.为什么我把print(count1)去掉count1返回的是0,改成return count1 也是返回的0
2,open(i,‘rb‘)打开.py类型的文件不是可以用'r'的形式,为什么这儿要用'rb'不然就会报错UnicodeDecodeError: 'gbk' codec can't decode byte 0xa5 in position 22: illegal multibyte sequence
  1. from easygui import *
  2. import os

  3. def search_file(path):
  4.     os.chdir(path)
  5.     for each_file in os.listdir(os.curdir):
  6.         (file_name,extend) = os.path.splitext(each_file)
  7.         if extend == '.py':
  8.             py_file.append(os.getcwd()+os.sep+each_file)
  9.         if os.path.isdir(each_file):
  10.             search_file(each_file)
  11.             os.chdir(os.pardir)

  12. py_file = []
  13. search_path = diropenbox()
  14. search_file(search_path)


  15. def count_line(files,count1):
  16.     for i in files:
  17.         f = open(i,'rb')
  18.         for each_line in f:
  19.             count1 += 1
  20.     print(count1)

  21. count1 = 0
  22. count_line(py_file,count1)
复制代码
最佳答案
2020-7-22 11:21:49

  1. from easygui import *
  2. import os

  3. def search_file(path):
  4.     os.chdir(path)
  5.     for each_file in os.listdir(os.curdir):
  6.         (file_name,extend) = os.path.splitext(each_file)
  7.         if extend == '.py':
  8.             py_file.append(os.getcwd()+os.sep+each_file)
  9.         # 如果这条 if 语句为真,你的程序 100% 会报错!
  10.         if os.path.isdir(each_file):
  11.             search_file(each_file)
  12.             os.chdir(os.pardir)

  13. py_file = []
  14. search_path = diropenbox('请选择你的代码库')
  15. search_file(search_path)


  16. def count_line(files,count1):
  17.     for i in files:
  18.         f = open(i,encoding='utf-8')
  19.         for each_line in f:
  20.             count1 += 1
  21.     return count1

  22. count1 = 0

  23. # 这里需要对 count1 变量进行重新赋值!
  24. count1 = count_line(py_file,count1)

  25. file_number = len(py_file)
  26. lack_row = 100000 - count1
  27. percentage = str(count1/100000*100)[:4] + '%'

  28. msg = '您目前共累计编写了%d行代码,完成进度:%s\n离10万行代码还差%d行,请继续努力!' % (count1,percentage,lack_row)
  29. title = '显示文件内容'
  30. text = '【.py】源文件%d个,源代码%d行' % (file_number,count1)
  31. textbox(msg,title,text)
复制代码


如果您对我的答案感到满意,请设置[b]最佳答案[b]!谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-7-22 10:32:51 | 显示全部楼层

编码错误,rb 是二进制打开读取,你应该试试 utf-8 编码:

  1. from easygui import *
  2. import os

  3. def search_file(path):
  4.     os.chdir(path)
  5.     for each_file in os.listdir(os.curdir):
  6.         (file_name,extend) = os.path.splitext(each_file)
  7.         if extend == '.py':
  8.             py_file.append(os.getcwd()+os.sep+each_file)
  9.         if os.path.isdir(each_file):
  10.             search_file(each_file)
  11.             os.chdir(os.pardir)

  12. py_file = []
  13. search_path = diropenbox()
  14. search_file(search_path)


  15. def count_line(files,count1):
  16.     for i in files:
  17.         f = open(i,encoding='utf-8')
  18.         for each_line in f:
  19.             count1 += 1
  20.     print(count1)

  21. count1 = 0
  22. count_line(py_file,count1)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-22 10:37:22 | 显示全部楼层
Twilight6 发表于 2020-7-22 10:32
编码错误,rb 是二进制打开读取,你应该试试 utf-8 编码:

直接f = open(i)为什么不行? 这个utf-8还没遇到过,我只是想单纯的读取行数,用二进制打开读取的行数会不会错?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-22 10:38:50 | 显示全部楼层
def花 发表于 2020-7-22 10:37
直接f = open(i)为什么不行? 这个utf-8还没遇到过,我只是想单纯的读取行数,用二进制打开读取的行数会 ...




Python 默认是 gbk 编码,如果文本是 utf-8 编码以 Python 默认打开就会报错了,因为 gbk 和 utf-8 编码字节不同

以二进制打开的文件你确定你能看得懂吗....
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-22 10:47:19 | 显示全部楼层
Twilight6 发表于 2020-7-22 10:38
Python 默认是 gbk 编码,如果文本是 utf-8 编码以 Python 默认打开就会报错了,因为 gbk 和 utf-8 ...

QAQ可是我在idle上就可以实现f = open(i),这又是为什么,我懵了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-22 10:52:02 | 显示全部楼层
除了楼上所提出的 bug 外,您的代码因为第 11 行的执行与导致第 12 行永远无法被执行,
所以无法改变您的工作目录。
我修改了您的代码以实现您想要的功能:
  1. from easygui import *
  2. import os

  3. def search_file(path):

  4.     for root,file_dir,file_list in os.walk(path):
  5.         for each_file in file_list:
  6.             if os.path.splitext(each_file)[1] == '.py':
  7.                 py_file.append(os.path.join(root,each_file))
  8.             

  9. py_file = []
  10. search_path = diropenbox()
  11. search_file(search_path)


  12. def count_line(files,count1):
  13.     for i in files:
  14.         f = open(i,'rb')
  15.         for each_line in f:
  16.             count1 += 1
  17.     print(f'您一共写了{count1}行代码。)

  18. count1 = 0
  19. count_line(py_file,count1)
复制代码


如果您对我的答案感到满意,请设置最佳答案
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-22 11:06:22 | 显示全部楼层
nahongyan1997 发表于 2020-7-22 10:52
除了楼上所提出的 bug 外,您的代码因为第 11 行的执行与导致第 12 行永远无法被执行,
所以无法改变您的 ...

大佬,你的方法比较高级QAQ,不过我执行出来所有文件也找齐了呀
}{72{G@P)REU}LQZ6]P5}8W.png
不过改print(count1)为return count1 ,count1为什么会一直返回0
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-7-22 11:12:48 | 显示全部楼层
def花 发表于 2020-7-22 11:06
大佬,你的方法比较高级QAQ,不过我执行出来所有文件也找齐了呀

不过改print(count1)为return count1  ...
  1. from easygui import *
  2. import os

  3. def search_file(path):

  4.     for root,file_dir,file_list in os.walk(path):
  5.         for each_file in file_list:
  6.             if os.path.splitext(each_file)[1] == '.py':
  7.                 py_file.append(os.path.join(root,each_file))
  8.             

  9. py_file = []
  10. search_path = diropenbox()
  11. search_file(search_path)


  12. def count_line(files,count1):
  13.     for i in files:
  14.         f = open(i,'rb')
  15.         for each_line in f:
  16.             count1 += 1
  17.     return f'您一共写了{count1}行代码。'

  18. count1 = 0
  19. print(count_line(py_file,count1))
复制代码


你可能是把 print 写成了这样:
  1. from easygui import *
  2. import os

  3. def search_file(path):

  4.     for root,file_dir,file_list in os.walk(path):
  5.         for each_file in file_list:
  6.             if os.path.splitext(each_file)[1] == '.py':
  7.                 py_file.append(os.path.join(root,each_file))
  8.             

  9. py_file = []
  10. search_path = diropenbox()
  11. search_file(search_path)


  12. def count_line(files,count1):
  13.     for i in files:
  14.         f = open(i,'rb')
  15.         for each_line in f:
  16.             count1 += 1
  17.     return f'您一共写了{count1}行代码。'

  18. count1 = 0
  19. count_line(py_file,count1)
  20. print(count1)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-22 11:13:04 | 显示全部楼层
为什么coun1会返回0  QAQ
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-7-22 11:14:14 | 显示全部楼层
nahongyan1997 发表于 2020-7-22 11:12
你可能是把 print 写成了这样:


我是这么写的
  1. from easygui import *
  2. import os

  3. def search_file(path):
  4.     os.chdir(path)
  5.     for each_file in os.listdir(os.curdir):
  6.         (file_name,extend) = os.path.splitext(each_file)
  7.         if extend == '.py':
  8.             py_file.append(os.getcwd()+os.sep+each_file)
  9.         if os.path.isdir(each_file):
  10.             search_file(each_file)
  11.             os.chdir(os.pardir)

  12. py_file = []
  13. search_path = diropenbox('请选择你的代码库')
  14. search_file(search_path)


  15. def count_line(files,count1):
  16.     for i in files:
  17.         f = open(i,encoding='utf-8')
  18.         for each_line in f:
  19.             count1 += 1
  20.     return count1

  21. count1 = 0
  22. count_line(py_file,count1)

  23. file_number = len(py_file)
  24. lack_row = 100000 - count1
  25. percentage = str(count1/100000*100)[:4] + '%'

  26. msg = '您目前共累计编写了%d行代码,完成进度:%s\n离10万行代码还差%d行,请继续努力!' % (count1,percentage,lack_row)
  27. title = '显示文件内容'
  28. text = '【.py】源文件%d个,源代码%d行' % (file_number,count1)
  29. textbox(msg,title,text)



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

使用道具 举报

发表于 2020-7-22 11:21:49 | 显示全部楼层    本楼为最佳答案   

  1. from easygui import *
  2. import os

  3. def search_file(path):
  4.     os.chdir(path)
  5.     for each_file in os.listdir(os.curdir):
  6.         (file_name,extend) = os.path.splitext(each_file)
  7.         if extend == '.py':
  8.             py_file.append(os.getcwd()+os.sep+each_file)
  9.         # 如果这条 if 语句为真,你的程序 100% 会报错!
  10.         if os.path.isdir(each_file):
  11.             search_file(each_file)
  12.             os.chdir(os.pardir)

  13. py_file = []
  14. search_path = diropenbox('请选择你的代码库')
  15. search_file(search_path)


  16. def count_line(files,count1):
  17.     for i in files:
  18.         f = open(i,encoding='utf-8')
  19.         for each_line in f:
  20.             count1 += 1
  21.     return count1

  22. count1 = 0

  23. # 这里需要对 count1 变量进行重新赋值!
  24. count1 = count_line(py_file,count1)

  25. file_number = len(py_file)
  26. lack_row = 100000 - count1
  27. percentage = str(count1/100000*100)[:4] + '%'

  28. msg = '您目前共累计编写了%d行代码,完成进度:%s\n离10万行代码还差%d行,请继续努力!' % (count1,percentage,lack_row)
  29. title = '显示文件内容'
  30. text = '【.py】源文件%d个,源代码%d行' % (file_number,count1)
  31. textbox(msg,title,text)
复制代码


如果您对我的答案感到满意,请设置[b]最佳答案[b]!谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-24 00:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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