|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
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)
这里不明白为什么要返回上一层,我觉得这条语句是永远不会被执行的,这个问题耗费了我一天去求解,现在还是没有一个明确的答案,哪位大神能提点一下,万分感谢!
|
|