这就是我所拥有的:
glob(os.path.join('src','*.c'))
但是我想搜索src的子文件夹.像这样的事情会奏效的:
glob(os.path.join('src','*.c'))
glob(os.path.join('src','*','*.c'))
glob(os.path.join('src','*','*','*.c'))
glob(os.path.join('src','*','*','*','*.c'))
但这显然是有限和笨拙的.
这就是我所拥有的:
glob(os.path.join('src','*.c'))
但是我想搜索src的子文件夹.像这样的事情会奏效的:
glob(os.path.join('src','*.c'))
glob(os.path.join('src','*','*.c'))
glob(os.path.join('src','*','*','*.c'))
glob(os.path.join('src','*','*','*','*.c'))
但这显然是有限和笨拙的.
pathlib.Path.rglob
使用Python 3.5中引入的pathlib
模块中的pathlib.Path.rglob
.
from pathlib import Path
for path in Path('src').rglob('*.c'):
print(path.name)
如果不想使用pathlib,use可以使用glob.glob('**/*.c')
,但不要忘记传入recursive
关键字参数,它会在大目录上占用大量时间.
对于以点(.
)开头的匹配文件;与当前目录中的文件或基于Unix系统上的隐藏文件一样,请使用下面的os.walk
解决方案.
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))