王亦可 发表于 2020-12-4 20:13:34

文件系统课后题目问题

2. 编写一个程序,用户输入文件名以及开始搜索的路径,搜索该文件是否存在。如遇到文件夹,则进入文件夹继续搜索

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)

这是给出的代码,我的问题是:递归调用后为什么要返回上一层目录?不是可以直接打印输出吗?

suchocolate 发表于 2020-12-4 20:31:06

os.chdir会改变整个脚本的工作位置,如果跳进子文件夹没有出来,递归调用完退回来遍历下一个外层的文件夹,其实还是在子文件搜索,是搜不到外层下一个文件夹,搜索就是空。

王亦可 发表于 2020-12-5 17:24:37

懂了,谢谢
页: [1]
查看完整版本: 文件系统课后题目问题