|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 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)[1] # 切割出 each_file 的后缀
- if ext in target: # 如果 ext 出现在 target 罗列的后缀当中
- lines = calc_code(each_file)
- # 那么久调用上面定义的函数 calc_code(),来统计它的行数
- # 如果字典中不存在这个文件的名字,就抛出 KeyError,然后添加字典键
- # 统计文件数
- try:
- file_list[ext] += 1
- # 后面会定义,file_list是一个字典。这里,在字典中,这个key对应的value上,加一。
- except KeyError:
- file_list[ext] = 1
- # 如果抛出 KeyError, 就保持不变。
- # 统计源代码行数
- try:
- source_list[ext] += lines
- # 这里,在字典中,这个key对应的value上,加上 lines 的值。
- except KeyError:
- source_list[ext] = lines
- # 如果抛出 KeyError, 就保持不变。
- if os.path.isdir(each_file): # 通过os.path中固定的 isdir 用法,来判断是否遇到了目录
- search_file(each_file)
- # 利用递归调用,解决遇到子目录的情况,可以无限循环直至找找到最终的文件
- os.chdir(os.pardir) # 递归调用后,切记,要重新返回上一层原先的目录
复制代码
每次都是返回上一层,而你递归是进入目录,这样恰好抵消了
在这27行 if 代码来说,递归 search_file() 进入几次,就会执行 os.chdir() 的次数是相同的
所以最后还是会返回最开始的工作目录
|
|