Python中g(shù)lob庫(kù)實(shí)現(xiàn)文件名的匹配
既然在Pathlib庫(kù)中提到了glob()函數(shù),那么我們就專門用一篇內(nèi)容講解文件名的匹配。其實(shí)我們有專門的一個(gè)文件名匹配庫(kù)就叫:glob。
不過(guò),glob庫(kù)的API非常小,但是僅僅應(yīng)用于文件名的匹配綽綽有余。只要是在實(shí)際的項(xiàng)目中需要過(guò)濾,或者匹配一組文件,都可以使用該庫(kù)進(jìn)行操作。
通配符星號(hào)(*)話不多說(shuō),下面我們使用通配符來(lái)匹配文件名,示例如下:
import globfor name in sorted(glob.glob(’text/*’)): print(name)
運(yùn)行之后,效果如下:
這里不僅用*通配符獲取了目錄下的所有文件,而且還對(duì)其進(jìn)行了排序。
問(wèn)號(hào)(?)問(wèn)號(hào)(?)是用來(lái)匹配單字的,比如我們賽選上面1開頭的圖片文件。示例如下:
import globfor name in glob.glob(’text/1?.png’): print(name)
運(yùn)行之后,效果如下:
從上面兩個(gè)匹配我們看出來(lái),glob庫(kù)的匹配規(guī)則與正則表達(dá)式有些相似。既然它能匹配模糊的,一個(gè)或多個(gè)字符,那么肯定也可以匹配區(qū)間字符。
示例如下:
import globfor name in glob.glob(’text/15[a-z].*’): print(name)
運(yùn)行之后,效果如下:
當(dāng)然,上面的文件名都是常規(guī)的文件名,都是用字母與數(shù)字組成的。但是,有些人比較怪,可能在文件名中包含了特殊的字符,比如上面的匹配字符“?*[”等。那怎么辦呢?用反斜杠“”轉(zhuǎn)義嗎?
其實(shí),我們還有更簡(jiǎn)單的,直接使用escape()函數(shù)進(jìn)行操作。示例如下:
import globescape_str=’?*[]’for char in escape_str: pattern = ’text/*’ + glob.escape(char) + ’.png’ for name in glob.glob(pattern):print(name)
運(yùn)行之后,效果如下:
到此這篇關(guān)于Python中g(shù)lob庫(kù)實(shí)現(xiàn)文件名的匹配的文章就介紹到這了,更多相關(guān)Python 文件名的匹配內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 學(xué)python最電腦配置有要求么2. Spring security 自定義過(guò)濾器實(shí)現(xiàn)Json參數(shù)傳遞并兼容表單參數(shù)(實(shí)例代碼)3. JAMon(Java Application Monitor)備忘記4. Java8內(nèi)存模型PermGen Metaspace實(shí)例解析5. python中用Scrapy實(shí)現(xiàn)定時(shí)爬蟲的實(shí)例講解6. 基于python實(shí)現(xiàn)操作git過(guò)程代碼解析7. python使用QQ郵箱實(shí)現(xiàn)自動(dòng)發(fā)送郵件8. Python Scrapy多頁(yè)數(shù)據(jù)爬取實(shí)現(xiàn)過(guò)程解析9. 解決redis與Python交互取出來(lái)的是bytes類型的問(wèn)題10. Python 的 __str__ 和 __repr__ 方法對(duì)比
