os.walk()
# os.walk()
作用:
- 主要用来遍历一个目录内各个子目录和子文件
- 是一个简单易用的文件、目录遍历器,可以帮助我们高效的处理文件、目录方面的事情
原理:递归遍历目录
# 方法参数介绍
os.walk(top[, topdown=True[, onerror=None[, followlinks=False]]])
1
- top :是要遍历的目录的地址, 返回的是一个三元组(dirpath, dirnames, filenames)
- topdown :可选,True 则优先遍历 top 文件夹,与 top 文件夹中每一个子目录;否则优先遍历 top 的子目录(默认为开启)
- onerror :可选,需要一个 callable 对象,当 walk 需要异常时,会调用
- followlinks :可选,如果为 True,则会遍历目录下的快捷方式(linux 下是软连接 symbolic link )实际所指的目录(默认关闭),如果为 False,则优先遍历 top 的子目录
# 返回的三元组介绍
dirpath:string,代表目录的路径
dirnames:list,包含了 dirpath 下所有子目录的名字
- filenames:list,包含了非目录文件的名字
# 代码示例
path = os.getcwd()
for dirpath, dirnames, filenames in os.walk(path):
print(dirpath)
print(dirnames)
print(filenames)
1
2
3
4
5
2
3
4
5
结果:
F:\pylearn\learn
['test']
['bytes_str.py', 'get_file_md5_test.py', 'List_Tuple_Learning.py', 'Number_Learning.py', 'os_walk.py', 'String_Learning.py', '__init__.py']
F:\pylearn\learn\test
[]
['test.py', '__init__.py']
1
2
3
4
5
6
2
3
4
5
6
知识点
当 top 路径下还有目录时,是会递归查询的
(完)