|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
# 编写一个程序,用户输入文件名以及开始搜索的路径,搜索该文件是否存在。如遇到文件夹,则进入文件夹继续搜索
import os
def myfun(catalog,file):
file_name = os.listdir(catalog) # 列举文件名
for each in file_name:
if each == file: #判断是否是需要查找的目标文件
print(os.path.join(catalog,each))
if os.path.isdir(each): #判断是否是文件夹
return myfun(os.path.join(catalog,each),file)
catalog = input('请输入待查找的初始目录:')
file = input('请输入需要查找的目标文件:')
myfun(catalog,file)
“如遇到文件夹,则进入文件夹继续搜索”这一要求无法实现是什么原因
因为你递归调用自身的时候,只有递进,没有回归。
你试着看一下代码,当进入一个文件夹判断完毕,进入子目录后没有退回到父级目录的操作(chdir(os.pardir))会导致无法遍历所有文件的目的。不要用return语句来做返回。
if 是文件夹:
调用自身
chdir(pardir))
每次调用完成都要回到父级目录,否则递归有去无回。
|
|