python用glob模块匹配路径的方法详解
glob模块是Python的一个标准库,用于在文件系统中查找文件名匹配特定模式的文件路径。
可以使用glob模块进行文件系统的通配符匹配,类似于在命令行中使用*和?通配符进行文件查找。
glob
glob可以通过通配符查找路径。例如
>>> import glob >>> for i in range(10): ... temp = open(str(i)+'.py','w') ... temp.close() ... >>> glob.glob(r'E:\Documents\00\1101\*.py')
返回值如下
[‘E:\Documents\00\1101\0.py’, ‘E:\Documents\00\1101\1.py’, ‘E:\Documents\00\1101\2.py’, ‘E:\Documents\00\1101\3.py’, ‘E:\Documents\00\1101\4.py’, ‘E:\Documents\00\1101\5.py’, ‘E:\Documents\00\1101\6.py’, ‘E:\Documents\00\1101\7.py’, ‘E:\Documents\00\1101\8.py’, ‘E:\Documents\00\1101\9.py’]
查看源码可以发现,glob是通过list(iglob(**))实现的,iglob返回一个符合要求路径的迭代器,glob将其转化为列表。
>>> it = glob.iglob(r'E:\Documents\00\1101\*.py') >>> next(it) 'E:\\Documents\\00\\1101\\0.py' >>> next(it) 'E:\\Documents\\00\\1101\\1.py' >>> next(it) 'E:\\Documents\\00\\1101\\2.py' >>> list(it) ['E:\\Documents\\00\\1101\\3.py', 'E:\\Documents\\00\\1101\\4.py', 'E:\\Documents\\00\\1101\\5.py', 'E:\\Documents\\00\\1101\\6.py', 'E:\\Documents\\00\\1101\\7.py', 'E:\\Documents\\00\\1101\\8.py', 'E:\\Documents\\00\\1101\\9.py']
fnmatch
除了*
可以被转义之外,glob还可以将[]?
等字符进行转义,其方法结合了os.scandir()
和fnmatch.fnmatch()
函数,例如
>>> glob.glob(r'E:\Documents\00\1101\[1-5].py')
[‘E:\Documents\00\1101\1.py’, ‘E:\Documents\00\1101\2.py’, ‘E:\Documents\00\1101\3.py’, ‘E:\Documents\00\1101\4.py’, ‘E:\Documents\00\1101\5.py’]
fnmatch是python中的文件夹匹配模块,其匹配规则为
模式 | * | ? | [seq] | [!seq] |
---|---|---|---|---|
含意 | 所有字符 | 任何单个字符 | seq中任何字符 | 不在seq中的字符 |
fnmatch中封装了一个正则表达式转化函数,可将fnmatch的匹配规则转为正则表达式的匹配规则,例如
>>> fnmatch.translate('[1-5]*.py') '(?s:[1-5].*\\.py)\\Z'
到此这篇关于python用glob模块匹配路径的方法详解的文章就介绍到这了,更多相关python glob匹配路径内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
SublimeText 2编译python出错的解决方法(The system cannot find the file
这篇文章主要介绍了SublimeText 2编译python报The system cannot find the file specified错误的解决方法,大家参考使用吧2013-11-11
最新评论