深度学习(PyTorch)——os.walk用法

python中os.walk是一个简单易用的文件、目录遍历器,可以帮助我们高效的处理文件、目录方面的事情

os.walk()用类似于深度遍历的方式遍历文件夹中的子文件夹以及文件。最基本的显示方式为(root_path,[file_dirs],[files]),比如文件夹dirty中有两个子文件夹toner、dirty以及一些图片文件,那么第一层显示方式为(~/dirty,[toner/dirty],[image1、image2、imag3…]),第二层显示方式为(~/dirty/toner,[],[image1,image2,image3…])、(~/dirty/dirty,[],[image1,image2,image3…]) 

1.载入

可以使用以下两种方法

  • import os

  • from os import walk

2.使用

os.walk的函数声明为:
walk(top, topdown=True, οnerrοr=None, followlinks=False)
参数
top 是你所要便利的目录的地址
topdown 为真,则优先遍历top目录,否则优先遍历top的子目录(默认为开启)
onerror 需要一个 callable 对象,当walk需要异常时,会调用
followlinks 如果为真,则会遍历目录下的快捷方式(linux 下是 symbolic link)实际所指的目录(默认关闭)
os.walk 的返回值是一个生成器(generator),也就是说我们需要不断的遍历它,来获得所有的内容。
 
每次遍历的对象都是返回的是一个三元组(root,dirs,files)
root 所指的是当前正在遍历的这个文件夹的本身的地址
dirs 是一个 list ,内容是该文件夹中所有的目录的名字(不包括子目录)
files 同样是 list , 内容是该文件夹中所有的文件(不包括子目录)
如果topdown 参数为真,walk 会遍历top文件夹,与top文件夹中每一个子目录。

3、举个例子 

如果我们有如下的文件结构

 

for (root, dirs, files) in os.walk('a'):
    #第一次运行时,当前遍历目录为 a
    所以 root == 'a'
         dirs == [ 'b', 'c', 'd']
         files == [ '4.txt', '5.txt']
     
    。。。
  
    # 接着遍历 dirs 中的每一个目录
    b:  root  = 'a\\b'
        dirs  = []
        files = [ '1.txt', '2.txt']
     
    # dirs为空,返回
    # 遍历c
    c:  root  = 'a\\c'
        dirs  = []
        files = [ '3.txt' ]
     
    PS : 如果想获取文件的全路径,只需要
    for f in files:
        path = os.path.join(root,f)
     
    # 遍历d
    d:  root  = 'a\\b'
        dirs  = []
        files = []
  
    遍历完毕,退出循环

参考文献:

https://blog.csdn.net/u012300744/article/details/81185474?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522166269808516800180632591%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=166269808516800180632591&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~sobaiduend~default-2-81185474-null-null.142^v47^body_digest,201^v3^control_1&utm_term=os.walk&spm=1018.2226.3001.4187

https://blog.csdn.net/chang995196962/article/details/107941320?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522166269808516800180632591%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=166269808516800180632591&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~baidu_landing_v2~default-3-107941320-null-null.142^v47^body_digest,201^v3^control_1&utm_term=os.walk&spm=1018.2226.3001.4187 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值