语法
以下是 walk()方法的语法:
os.walk(top[, topdown=True[, οnerrοr=None[, followlinks=False]]])
参数
top --在目录每个目录根,得到3元组,即(dirpath, dirnames, filenames)
topdown -- 如果可选参数 topdown 的值是Ture或未指定,则目录从自上而下的扫描。 如果 topdown 设置为False,目录从自下而上的扫描。
onerror -- 这可能会显示错误继续遍历文件,或引发异常中止遍历。
followlinks -- 这可访问目录指向符号链接,如果设置为true。
返回值
此方法不返回任何值。
示例
下面的示例显示 walk()方法的使用。
# !/usr/bin/python3
import os
os.chdir("d:\\tmp")
for root, dirs, files in os.walk(".", topdown=False):
for name in files:
print(os.path.join(root, name))
for name in dirs:
print(os.path.join(root, name))
让我们编译并运行上述程序,这将扫描所有的目录和子目录,结果如下所示:
.\python2\testdir\Readme_files\Lpt_Port_Config.gif
.\python2\testdir\Readme_files\ParallelPortViever.gif
.\python2\testdir\Readme_files\softcollection.css
.\python2\testdir\Readme_files\Thumbs.db
.\python2\testdir\Readme_files\Yellov_Ball.gif
.\python2\testdir\Readme.html
.\python2\testdir\Readme_files
.\python2\testdir
.\Applicationdocs.docx
.\book.zip
.\foo.txt
.\java.ppt
.\python2
如果你将 topdown 改变前的值为 True,那么它会得到以下结果:
.\Applicationdocs.docx
.\book.zip
.\foo.txt
.\java.ppt
.\python2
.\python2\testdir
.\python2\testdir\Readme.html
.\python2\testdir\Readme_files
.\python2\testdir\Readme_files\Lpt_Port_Config.gif
.\python2\testdir\Readme_files\ParallelPortViever.gif
.\python2\testdir\Readme_files\softcollection.css
.\python2\testdir\Readme_files\Thumbs.db
.\python2\testdir\Readme_files\Yellov_Ball.gif