Peteryo01223 发表于 2021-2-1 16:33:47

第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) # 递归调用后,切记,要重新返回上一层原先的目录

Twilight6 发表于 2021-2-1 16:36:36



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

Peteryo01223 发表于 2021-2-1 16:38:52

Twilight6 发表于 2021-2-1 16:36
os.chdir() 函数都是返回当前目录的上一层

好的。那么,出现多级子目录的情况时,python 是通过哪句 code,多级返回的呢?它总要返回初始目录位置的吧?

qiuyouzhi 发表于 2021-2-1 16:46:24

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

递归完成后依次返回

Twilight6 发表于 2021-2-1 16:46:59

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



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

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

所以最后还是会返回最开始的工作目录

Peteryo01223 发表于 2021-2-1 21:15:37

qiuyouzhi 发表于 2021-2-1 16:46
递归完成后依次返回

言简意赅,学习了,谢谢!
页: [1]
查看完整版本: 第35课:EasyGui 最后一题。