第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
如果不返回上一层目录
程序就卡在这个子目录里出不来了
嗷,懂了~调用后目录变成子目录了,返回的上一级目录就是调用函数之前的当前目录{:10_279:}
页:
[1]