os.walk(top, topdown=True, onerror=None, followlinks=False)
可以得到一个三元tupple(dirpath, dirnames, filenames),
第一个为起始路径,第二个为起始路径下的文件夹,第三个是起始路径下的文件。
dirpath 是一个string,代表目录的路径, 遍历过程中是不断变化的
dirnames 是一个list,包含了dirpath下所有子目录的名字。(只是目录名,没有全路径)
filenames 是一个list,包含了dirpath下所有文件的名字。(只是文件名,没有全路径)
如果需要得到全路径,需要使用os.path.join(dirpath, dirnames ). 注意dirnames是个列表,要需要循环遍历,才能得到每个文件的路径
import os filepath="C:\\02xuzhangli\\python\\test" for each in os.walk(filepath): #each 是一个三元tuple print(each)
>>>每个each都是一个三元元祖,each[0]:目录 each[1]:目录下的文件夹名字 each[2]:目录下的文件名字
(‘C:\\02xuzhangli\\python\\test‘, [‘a‘, ‘testdir‘], [‘cat2.txt‘, ‘copy.py‘, ‘copy.pyc‘, ‘getjpg.py‘, ‘hello.py‘, ‘test.py‘, ‘test.txt‘]) (‘C:\\02xuzhangli\\python\\test\\a‘, [‘b‘], []) (‘C:\\02xuzhangli\\python\\test\\a\\b‘, [‘c‘], []) (‘C:\\02xuzhangli\\python\\test\\a\\b\\c‘, [‘test1‘], []) (‘C:\\02xuzhangli\\python\\test\\a\\b\\c\\test1‘, [], [‘新建文本文档.txt‘]) (‘C:\\02xuzhangli\\python\\test\\testdir‘, [‘f1‘, ‘f2‘, ‘f3‘, ‘jpg‘], []) (‘C:\\02xuzhangli\\python\\test\\testdir\\f1‘, [], []) (‘C:\\02xuzhangli\\python\\test\\testdir\\f2‘, [], []) (‘C:\\02xuzhangli\\python\\test\\testdir\\f3‘, [], []) (‘C:\\02xuzhangli\\python\\test\\testdir\\jpg‘, [], [‘cal.py‘])
得到文件全路径的方法:
import os filepath="C:\\02xuzhangli\\python\\test" for each_tuple in os.walk(filepath): for each_file in each_tuple[2]: #each_tuple[2] 文件list 一个list print(os.path.join(each_tuple[0],each_file)) #each_tuple[0] 目录名 一个string
>>>#出力结果 每个文件的完整路径 C:\02xuzhangli\python\test\a.bat C:\02xuzhangli\python\test\cal.py C:\02xuzhangli\python\test\cal.pyc C:\02xuzhangli\python\test\cal1.py C:\02xuzhangli\python\test\cat.txt C:\02xuzhangli\python\test\cat2.txt C:\02xuzhangli\python\test\copy.py C:\02xuzhangli\python\test\copy.pyc C:\02xuzhangli\python\test\getjpg.py C:\02xuzhangli\python\test\hello.py C:\02xuzhangli\python\test\test.py C:\02xuzhangli\python\test\test.txt C:\02xuzhangli\python\test\a\b\c\test1\新建文本文档.txt C:\02xuzhangli\python\test\testdir\jpg\cal.py
时间: 2024-12-23 11:10:21