Python - os.walk()简单介绍

os.walk()是Python中用于遍历目录及其子目录的函数,返回三元组(dirpath,dirnames,filenames),提供递归查询功能。它接受参数如topdown、onerror和followlinks,分别控制遍历顺序、错误处理和是否跟随符号链接。示例代码展示了如何使用os.walk()打印当前目录及其子目录的信息。
摘要由CSDN通过智能技术生成

os.walk() 方法简单介绍

  • 主要用来遍历一个目录内各个子目录和子文件
  • 是一个简单易用的文件、目录遍历器,可以帮助我们高效的处理文件、目录方面的事情。

方法参数介绍

os.walk(top[, topdown=True[, οnerrοr=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])
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值