os.walk 遍历目录下目录和文件
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
运行结果:
从结果可以看出遍历的流程