使用不同方法递归查找文件
在目录结构中递归搜索文件时,glob() 可能不是最有效的,或者综合方法。本文探讨了实现递归文件列表的替代方法:
pathlib.Path().rglob()
pathlib 模块引入了 pathlib.Path().rglob( ),它递归地搜索匹配的文件。示例:
from pathlib import Path for path in Path('src').rglob('*.c'): print(path.name)
glob.glob() with recursive=True
对于 3.5 之前的 Python 版本,glob.glob() 提供递归选项。示例:
from glob import glob for filename in glob('src/**/*.c', recursive=True): print(filename)
os.walk()
对于较旧的 Python 版本,os.walk() 与 fnmatch.filter() 结合提供递归搜索。示例:
import fnmatch import os matches = [] for root, dirnames, filenames in os.walk('src'): for filename in fnmatch.filter(filenames, '*.c'): matches.append(os.path.join(root, filename))
os.walk() 方法迭代所有子目录,而 fnmatch.filter() 应用简单的模式匹配。由于与 pathlib 相比,这种方法的开销较低,因此对于大型目录可能更有效。
以上是在 Python 中递归查找文件的最佳方法是什么?的详细内容。更多信息请关注PHP中文网其他相关文章!