版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lilong117194/article/details/74503143

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

1.载入
要使用os.walk,首先要载入该函数

可以使用以下两种方法

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文件夹中每一个子目录。

例子:

from os import walk
import pandas as pd

dataframe_list = []
#walk会返回3个参数,分别是路径,目录list,文件list,你可以按需修改下
for f, _, i in walk(“E:\names”):
for j in i:
dataframe_list.append(pd.read_csv(f + “\” + j))

# coding=utf-8
import os
mypath = "C:\\Users\\LiLong\\Desktop\\tt"

for root , dirs, files in os.walk(mypath):
    print(root)
    print(dirs)
    print(files)
print('..................................................')    
for root,dirs,files in os.walk(mypath):
    print(root)
    for dr in dirs:
        print(dr)
    for name in files:
        if name.endswith(".txt"):
            print(os.path.join(root, name))
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

运行结果:

从结果可以看出遍历的流程

参考:> http://www.jianshu.com/p/bbad16822eab