叱咤风云2333 发表于 2020-5-8 16:19:17

第30课后题,文件递归后为什么要返回上一级目录

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

第11行,为什么递归调用后一定要返回上一层目录,而不是继续在当前目录下搜索?

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)

wuqramy 发表于 2020-5-8 16:20:21

如果不返回上一层目录
程序就卡在这个子目录里出不来了

叱咤风云2333 发表于 2020-5-8 16:26:11

wuqramy 发表于 2020-5-8 16:20
如果不返回上一层目录
程序就卡在这个子目录里出不来了

嗷,懂了~调用后目录变成子目录了,返回的上一级目录就是调用函数之前的当前目录{:10_279:}
页: [1]
查看完整版本: 第30课后题,文件递归后为什么要返回上一级目录