Python - os.walk()详细使用
os.walk() 方法简单介绍
- 主要用来遍历一个目录内各个子目录和子文件
- 是一个简单易用的文件、目录遍历器,可以帮助我们高效的处理文件、目录方面的事情。
方法参数介绍
os.walk(top[, topdown=True[, onerror=None[, followlinks=False]]])
- 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)
测试结果
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']
包含知识点
可以看到当你top路径下还有目录时,是会递归查询的
上面的代码等价于下面的代码,当然不建议这样写,因为不够清晰明了
for data in os.walk(path): print(data[0]) print(data[1]) print(data[2])