第35课:EasyGui 最后一题。
本帖最后由 Peteryo01223 于 2021-2-1 16:39 编辑原题目:写一个程序统计你当前代码量的总和,并显示离十万行代码量还有多远?
以下代码:仅为标准答案中间的一小部分,它定义了一个函数search_file(),因为文件夹中很可能还有多级文件夹。这个函数,用递归,解决了多层文件夹的问题。
请问:在有若干子目录一层套一层的情况下,第30行到底是让 Python 返回了一层目录呢?还是直接返回了本程序开始时的初始目录位置呢?Python运行过程,能否尽量用文字帮我描述以下?以便我理解。谢谢。
以下,为部分标准答案,其它省略。
def search_file(start_directory):
os.chdir(start_directory) # 确保在 current directory 中
for each_file in os.listdir(os.curdir): # 每一个当前目录下,列出的文件名中
ext = os.path.splitext(each_file) # 切割出 each_file 的后缀
if ext in target: # 如果 ext 出现在 target 罗列的后缀当中
lines = calc_code(each_file)
# 那么久调用上面定义的函数 calc_code(),来统计它的行数
# 如果字典中不存在这个文件的名字,就抛出 KeyError,然后添加字典键
# 统计文件数
try:
file_list += 1
# 后面会定义,file_list是一个字典。这里,在字典中,这个key对应的value上,加一。
except KeyError:
file_list = 1
# 如果抛出 KeyError, 就保持不变。
# 统计源代码行数
try:
source_list += lines
# 这里,在字典中,这个key对应的value上,加上 lines 的值。
except KeyError:
source_list =lines
# 如果抛出 KeyError, 就保持不变。
if os.path.isdir(each_file): # 通过os.path中固定的 isdir 用法,来判断是否遇到了目录
search_file(each_file)
# 利用递归调用,解决遇到子目录的情况,可以无限循环直至找找到最终的文件
os.chdir(os.pardir) # 递归调用后,切记,要重新返回上一层原先的目录
os.chdir() 函数都是返回当前目录的上一层
Twilight6 发表于 2021-2-1 16:36
os.chdir() 函数都是返回当前目录的上一层
好的。那么,出现多级子目录的情况时,python 是通过哪句 code,多级返回的呢?它总要返回初始目录位置的吧? Peteryo01223 发表于 2021-2-1 16:38
好的。那么,出现多级子目录的情况时,python 是通过哪句 code,多级返回的呢?它总要返回初始目录位置的 ...
递归完成后依次返回 Peteryo01223 发表于 2021-2-1 16:38
好的。那么,出现多级子目录的情况时,python 是通过哪句 code,多级返回的呢?它总要返回初始目录位置的 ...
每次都是返回上一层,而你递归是进入目录,这样恰好抵消了
在这27行 if 代码来说,递归 search_file() 进入几次,就会执行 os.chdir() 的次数是相同的
所以最后还是会返回最开始的工作目录
qiuyouzhi 发表于 2021-2-1 16:46
递归完成后依次返回
言简意赅,学习了,谢谢!
页:
[1]