鱼C论坛

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

[已解决]第35课:EasyGui 最后一题。

[复制链接]
发表于 2021-2-1 16:33:47 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 Peteryo01223 于 2021-2-1 16:39 编辑

原题目:写一个程序统计你当前代码量的总和,并显示离十万行代码量还有多远?

以下代码:仅为标准答案中间的一小部分,它定义了一个函数search_file(),因为文件夹中很可能还有多级文件夹。这个函数,用递归,解决了多层文件夹的问题。

请问:在有若干子目录一层套一层的情况下,第30行到底是让 Python 返回了一层目录呢?还是直接返回了本程序开始时的初始目录位置呢?Python运行过程,能否尽量用文字帮我描述以下?以便我理解。谢谢。

以下,为部分标准答案,其它省略。
  1. def search_file(start_directory):
  2.     os.chdir(start_directory) # 确保在 current directory 中

  3.     for each_file in os.listdir(os.curdir): # 每一个当前目录下,列出的文件名中
  4.         ext = os.path.splitext(each_file)[1] # 切割出 each_file 的后缀
  5.         if ext in target: # 如果 ext 出现在 target 罗列的后缀当中
  6.             lines = calc_code(each_file)
  7.             # 那么久调用上面定义的函数 calc_code(),来统计它的行数

  8.             # 如果字典中不存在这个文件的名字,就抛出 KeyError,然后添加字典键
  9.             # 统计文件数
  10.             try:
  11.                 file_list[ext] += 1
  12.                 # 后面会定义,file_list是一个字典。这里,在字典中,这个key对应的value上,加一。
  13.             except KeyError:
  14.                 file_list[ext] = 1
  15.                 # 如果抛出 KeyError, 就保持不变。

  16.             # 统计源代码行数
  17.             try:
  18.                 source_list[ext] += lines
  19.                 # 这里,在字典中,这个key对应的value上,加上 lines 的值。
  20.             except KeyError:
  21.                 source_list[ext] =  lines
  22.                 # 如果抛出 KeyError, 就保持不变。

  23.         if os.path.isdir(each_file): # 通过os.path中固定的 isdir 用法,来判断是否遇到了目录
  24.             search_file(each_file)
  25.             # 利用递归调用,解决遇到子目录的情况,可以无限循环直至找找到最终的文件
  26.             os.chdir(os.pardir) # 递归调用后,切记,要重新返回上一层原先的目录
复制代码
最佳答案
2021-2-1 16:46:59
Peteryo01223 发表于 2021-2-1 16:38
好的。那么,出现多级子目录的情况时,python 是通过哪句 code,多级返回的呢?它总要返回初始目录位置的 ...




每次都是返回上一层,而你递归是进入目录,这样恰好抵消了

在这27行 if 代码来说,递归 search_file() 进入几次,就会执行 os.chdir() 的次数是相同的

所以最后还是会返回最开始的工作目录
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-2-1 16:36:36 | 显示全部楼层


os.chdir() 函数都是返回当前目录的上一层

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

使用道具 举报

 楼主| 发表于 2021-2-1 16:38:52 | 显示全部楼层
Twilight6 发表于 2021-2-1 16:36
os.chdir() 函数都是返回当前目录的上一层

好的。那么,出现多级子目录的情况时,python 是通过哪句 code,多级返回的呢?它总要返回初始目录位置的吧?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-2-1 16:46:24 | 显示全部楼层
Peteryo01223 发表于 2021-2-1 16:38
好的。那么,出现多级子目录的情况时,python 是通过哪句 code,多级返回的呢?它总要返回初始目录位置的 ...

递归完成后依次返回
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-2-1 16:46:59 | 显示全部楼层    本楼为最佳答案   
Peteryo01223 发表于 2021-2-1 16:38
好的。那么,出现多级子目录的情况时,python 是通过哪句 code,多级返回的呢?它总要返回初始目录位置的 ...




每次都是返回上一层,而你递归是进入目录,这样恰好抵消了

在这27行 if 代码来说,递归 search_file() 进入几次,就会执行 os.chdir() 的次数是相同的

所以最后还是会返回最开始的工作目录
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

 楼主| 发表于 2021-2-1 21:15:37 From FishC Mobile | 显示全部楼层
qiuyouzhi 发表于 2021-2-1 16:46
递归完成后依次返回

言简意赅,学习了,谢谢!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-26 03:47

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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