|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 geen 于 2019-7-3 13:40 编辑
问题:如果需要处理大量的数据,相比小甲鱼的方法,使用os.walk()效率会更低吗?
第30讲第02题:
编写一个程序,用户输入文件名以及开始搜索的路径,搜索该文件是否存在。如遇到文件夹,则进入文件夹继续搜索,程序实现如图:
https://fishc.com.cn/forum.php?m ... peid%26typeid%3D398
小甲鱼的代码:
- 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)
复制代码
我的代码:
- import os
- startdir = input(r'请输入待查找的初始目录:')
- targetfile = input('请输入需要查找的目标文件:')
- allfiles = os.walk(startdir)
- for eachfile in allfiles:
- if targetfile in eachfile[2]:
- print(eachfile[0]+'\\'+targetfile)
复制代码
|
|