|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
代码:
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)
问题:
search_file(each_file, target) # 递归调用
os.chdir(os.pardir) # 递归调用后切记返回上一层目录
这里的递归在满足each_file == target时会跳出,但是如果两个判断语句都不成立,他是如何跳出当前递归执行下一语句 os.chdir(os.pardir)
递归找到就打印并结束
找不到就继续下一级目录 如果找到就打印结束 没找到就结束
如果到了底级目录没找到 就结束了 然后返回父目录中的 下一个目录 继续递归
由此可见 递归既不好理解 也不好写 反正我是干脆不研究
|
|