|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
问题:这个递归调用字典本身的行为,在业务逻辑是实现了什么?实际运行的效果是怎么样的?
search_file(each_file, target) #那么递归调用each_file
os.chdir(os.pardir) #递归调用后切记返回上一层目录
题目:
编写一个程序,用户输入文件名以及开始搜索的路径,搜索该文件是否存在。
如果遇到文件夹,则进入文件夹继续搜索,程序实现如图:
代码:
import os
def search_file(star_dir, target):#字典的格式为(原文件 目标文件)
os.chdir(start_dir) #改变工作目录为star_dir
for each_file in os.listdir(os.curdir): #列出当前目录全部内容(文件和目录)
if each_file == target: #如果当前文件为目标文件
print(os.getced() +os.sep + each_file) #那么返回当前工作目录+路径分隔符/+全部文件内容
if os.path.isdir(each_file): #如果each_file是否存在,且是一个目录
search_file(each_file, target) #那么递归调用each_file
os.chdir(os.pardir) #递归调用后切记返回上一层目录
strat_dir = input('请输入待查找的初始目录:')
target = input('请输入需要查找的目标文件:')
search_file(start_dir, target)
字典毛关系没有
程序逻辑就是开门进来没找到人出去换个屋继续找,有里屋的再进里屋里找
|
|