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])

 

posted @ 2020-02-23 12:41  小菠萝测试笔记  阅读(8919)  评论(0编辑  收藏  举报