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
因为如果不返回上一层目录,程序就陷在子目录里出不来了
不好意思我还是不太明白,递归调用后的函数也重新定义了当前目录,程序为什么会卡住呢? zltzlt 发表于 2020-5-3 21:21
因为如果不返回上一层目录,程序就陷在子目录里出不来了
是说程序会卡在第一个底层子目录里,没办法开始递归下一个子目录吗 白板鱼人 发表于 2020-5-3 21:46
是说程序会卡在第一个底层子目录里,没办法开始递归下一个子目录吗
是的
页:
[1]