资料来源:https://blog.csdn.net/xc_zhou/article/details/85329980
此模块提供了Unix shell 风格的通配符,它们并不等同于正则表达式(关于后者的文档参见re 模块)。shell风格通配符所使用的特殊字符如下:
模式 | 含义 |
---|---|
* | 匹配所有 |
? | 匹配任何单个字符 |
[seq] | 匹配seq 中的任何字符 |
[!seq] | 匹配任何不在seq 中的字符 |
例子中,主要使用os.listdir来列出当前目录中的文件,如果匹配的后缀为.txt,那么就打印出来,fnmatch.fnmatch是一个布尔函数,返回为True或者Faulse。
主要使用的匹配模式如下:
if fnmatch.fnmatch('kel','?el'): #匹配模式为问号,及匹配一个任意字符
print('match')
if fnmatch.fnmatch('kel','[a-z]el'): #匹配模式为单个字符,在a-z之间
print('match')
if fnmatch.fnmatch('1el','[!a-z]el'):#匹配模式为不能是a-z之间的字符
print('match')
问号相当于一个占位符,从而能匹配
k是字母a-z之间的字母,从而能匹配
数字1不在a-z之间的字母,从而能匹配
1.fnmatch
- fnmatch.fnmatch(filename, pattern)
- 测试filename,是否符合pattern。
import fnmatch
import os
def run():
for file in os.listdir('.'): #os.listdir返回指定的文件夹包含的文件或文件夹的名字的列表
if fnmatch.fnmatch(file, '*.py'): #判断是否有后缀为.py的文件,*代表文件名长度格式不限制。
print(file)
if __name__ == '__main__':
run()
"""
1.txt
a.txt
"""
2.fnmatchcase
- fnmatch.fnmatchcase(filename, pattern)
- 和fnmatch()类似,只是fnmatchcase 强制区分大小写匹配,不管文件系统是否区分。
print(fnmatch.fnmatchcase("text.py","text.*")) #True
print(fnmatch.fnmatchcase("Text.py", "text.*")) # False
print(fnmatch.fnmatchcase("Text.Py", "*.py")) # False
print(fnmatch.fnmatchcase("Text.Py", "*.Py")) # True
3.filter
- fnmatch.filter(names, pattern)
- 实现列表特殊字符的过滤或筛选,返回符合匹配模式的字符列表,它的作用类似[n for n in names if fnmatch(n, pattern)],但实现得更有效率
filelist=["a.text","b.jpg","c.png","d.py",'e.text',"sss.py"]
print(fnmatch.filter(filelist,"?.py")) #匹配前面是一个字符的.py文件
输出:d.py
4.translate
- fnmatch.translate(pattern):
- 翻译模式, fnmatch将这种全局模式转换成一个正则式, 然后使用re模块来比较名字和模式。 translate() 函数是一个公共API用于将全局模式转换成正则式
regex = fnmatch.translate('[f,d,d,d,g,h].txt')#将[f,d,d,d,g,h].txt转为正则匹配的模式
print("regex",regex)#(?s:[f,d,d,d,g,h]\.txt)\Z
#\Z:匹配字符串结束,如果是存在换行,只匹配到换行前的结束字符串。
reobj = re.compile(regex)#生成re匹配模块
print(reobj.match ('f.txt'))#返回一个匹配对象
#<_sre.SRE_Match object; span=(0, 5), match='f.txt'>