對的,`fnmatch`模塊是Python標(biāo)準(zhǔn)庫中的一個(gè)模塊,用于實(shí)現(xiàn)文件名的匹配操作。它提供了簡單的模式匹配功能,可用于過濾文件名或路徑名的列表。
以下是`fnmatch`模塊中常用的函數(shù):
- `fnmatch(name, pattern)`: 判斷給定的`name`是否匹配指定的`pattern`。`name`是要匹配的文件名或路徑名,`pattern`是模式字符串,支持使用通配符`*`和`?`進(jìn)行匹配。
- `filter(names, pattern)`: 從給定的`names`列表中返回匹配指定`pattern`的名稱列表。`names`是一個(gè)文件名或路徑名列表,`pattern`是模式字符串。
- `translate(pattern)`: 將模式字符串轉(zhuǎn)換為內(nèi)部使用的正則表達(dá)式模式。該函數(shù)返回轉(zhuǎn)換后的正則表達(dá)式字符串。
下面是一些使用`fnmatch`模塊的示例:
import fnmatch
# 使用fnmatch進(jìn)行簡單的文件名匹配
if fnmatch.fnmatch('file.txt', '*.txt'):
print('Matched!')
# 使用fnmatch.filter過濾文件名列表
file_list = ['file.txt', 'image.jpg', 'data.csv', 'script.py']
filtered_files = fnmatch.filter(file_list, '*.txt')
print(filtered_files) # ['file.txt']
# 使用fnmatch.translate轉(zhuǎn)換模式字符串為正則表達(dá)式
pattern = fnmatch.translate('file*.txt')
print(pattern) # ^file.*\.txt$
通過`fnmatch`模塊,你可以方便地進(jìn)行文件名的模式匹配,以便篩選和操作文件。請注意,`fnmatch`模塊匹配的是基本的通配符模式,并不支持正則表達(dá)式的高級匹配功能。如果需要更復(fù)雜的模式匹配,可以使用`re`模塊來進(jìn)行正則表達(dá)式匹配。