一个问题
要求是:编写一个程序,用户输入文件名以及开始搜索的路径,搜索该文件是否存在。如遇到文件夹,则进入文件夹继续搜索
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)
就想问一下,问为什么递归调用后要 返回上一层目录?
假设文件夹的结构是这样的,当你递归调用的时候从A进入到了B,如果你还想访问C的话,不就应该把指针返回到上一层目录吗 shuofxz 发表于 2016-3-1 17:36
假设文件夹的结构是这样的,当你递归调用的时候从A进入到了B,如果你还想访问C的话,不就应该把指针返回 ...
这个循环,如果这两个if 都不成立的话,程序会怎么运行啊? shuofxz 发表于 2016-3-1 17:36
假设文件夹的结构是这样的,当你递归调用的时候从A进入到了B,如果你还想访问C的话,不就应该把指针返回 ...
假如D E F都是.txt 格式的。我的目标是找到F文件,当程序寻找到D的时候,发现D既不是目标文件,也不是文件夹,那么下一步程序会做什么? 没有人能帮帮忙吗????真的搞不懂了。。。 swsfly 发表于 2016-3-3 20:55
没有人能帮帮忙吗????真的搞不懂了。。。
想知道楼主多年以后懂了么0.0 哟,这是几年前
页:
[1]