def花 发表于 2020-7-15 12:41:27

课后作业30

import os

def search_file(start_dir, target) :
    os.chdir(start_dir)
   
    for each_file in os.listdir(os.curdir) :
      if each_file == target :
            print(os.getcwd() + os.sep + each_file) # 使用os.sep是程序更标准
      if os.path.isdir(each_file) :
            search_file(each_file, target) # 递归调用
            os.chdir(os.pardir) # 递归调用后切记返回上一层目录

start_dir = input('请输入待查找的初始目录:')
target = input('请输入需要查找的目标文件:')
search_file(start_dir, target)


为什么要切记返回上一层目录???想不通,反正都要os.chdir(each_file)改变工作目录。

Twilight6 发表于 2020-7-15 12:46:14

本帖最后由 Twilight6 于 2020-7-15 12:51 编辑



就是因为你 os.chdir(each_file) 改变了工作目录了,所以要返回上一层目录

举个例子 比如我们循环 C:\py 文件夹里的内容py文件夹里面有 test 、ttt 两个文件夹

你通过 os.chdir 改变工作目录到 C:\py\test 了 ,然后如果不返回那么下次循环就在这个 C:\py\test 工作目录中查找

但是 ttt 文件夹我们都还没查找完,就是因为你没有查找完毕后返回上一层目录,所以你这里递归查找文件夹只会遇到一个文件夹就进去一个文件夹,如果此时 test 还有两个文件夹 aaa、bbb

你又一次的遍历到 aaa 后通过 os.chdir 改变工作目录为 C:\py\test\aaa ,不返回上一层就会又一次的将 bbb 文件夹给遗漏了

所以这里如果没有设置返回上一层目录,那么永远就只进不出,导致遍历实际上只循环了一个大路径,比如这里的例子C:\py\test\aaa    , 遗漏了很多文件夹比如这里的 ttt、bbb 文件夹没有去遍历循环

只有递归查找完毕后返回上一层目录,才会再次进入同目录下的其他文件夹进行查找文件

def花 发表于 2020-7-15 16:22:24

Twilight6 发表于 2020-7-15 12:46
就是因为你 os.chdir(each_file) 改变了工作目录了,所以要返回上一层目录

举个例子 比如我们循环 C ...

有点懂了
页: [1]
查看完整版本: 课后作业30