白板鱼人 发表于 2020-5-3 21:18:22

Python第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)



请问大佬们函数定义的开头都手动改变工作目录了,为什么递归调用后要返回上一层目录呀?

zltzlt 发表于 2020-5-3 21:21:24

因为如果不返回上一层目录,程序就陷在子目录里出不来了

白板鱼人 发表于 2020-5-3 21:33:12

zltzlt 发表于 2020-5-3 21:21
因为如果不返回上一层目录,程序就陷在子目录里出不来了

不好意思我还是不太明白,递归调用后的函数也重新定义了当前目录,程序为什么会卡住呢?

白板鱼人 发表于 2020-5-3 21:46:08

zltzlt 发表于 2020-5-3 21:21
因为如果不返回上一层目录,程序就陷在子目录里出不来了

是说程序会卡在第一个底层子目录里,没办法开始递归下一个子目录吗

zltzlt 发表于 2020-5-3 21:48:10

白板鱼人 发表于 2020-5-3 21:46
是说程序会卡在第一个底层子目录里,没办法开始递归下一个子目录吗

是的
页: [1]
查看完整版本: Python第30讲课后练习