簡(jiǎn)單掌握Python中g(shù)lob模塊查找文件路徑的用法
glob使用UNIX shell規(guī)則查找與一個(gè)模式匹配的文件名。只要程序需要查找文件系統(tǒng)中名字與某個(gè)模式匹配的一組文件,就可以使用這個(gè)模塊。
glob的模式規(guī)則與re模塊使用的正則表達(dá)式不相同。glob模式遵循標(biāo)準(zhǔn)UNIX路徑擴(kuò)展規(guī)則。只是用幾個(gè)特殊字符來實(shí)現(xiàn)兩個(gè)不同的通配符和字符區(qū)間。模式規(guī)則要應(yīng)用于文件名中的段。模式中的路徑可以是相對(duì)路徑或絕對(duì)路徑。
shell變量名和波浪線都不會(huì)擴(kuò)展。
基本用法
1.glob.glob(pathname), 返回所有匹配的文件路徑列表。它只有一個(gè)參數(shù)pathname,定義了文件路徑匹配規(guī)則,這里可以是絕對(duì)路徑,也可以是相對(duì)路徑。
2.glob.iglob(pathname), 獲取一個(gè)可編歷對(duì)象,使用它可以逐個(gè)獲取匹配的文件路徑名。與glob.glob()的區(qū)別是:glob.glob同時(shí)獲取所有的匹配路徑,而glob.iglob一次只獲取一個(gè)匹配路徑。
3.eg:
import glob print glob.glob(r'E:\*\*.doc') print glob.glob(r'.\*.py') f = glob.iglob(r'.\*.py') for py in f: print py
運(yùn)行結(jié)果:
['E:\\test_file\\adplus.doc'] ['.\\perfrom_test.py', '.\\pyTest.py', '.\\simulation_login.py', '.\\widget.py', '.\\__init__.py'] .\perfrom_test.py .\pyTest.py .\simulation_login.py .\widget.py .\__init__.py
下面我們分知識(shí)點(diǎn)詳細(xì)來講:
通配符
星號(hào)匹配一個(gè)文件名段中的0個(gè)或多個(gè)字符。
import glob for name in glob.glob('tmp/*'): print name
這個(gè)模式會(huì)匹配所有的路徑名,但是不會(huì)遞歸搜索到子目錄。
>>> ================================ RESTART ================================ >>> tmp\checklog_status.sh tmp\check_Adwords_v1.2.sh tmp\check_traffic.sh tmp\cut_nginxlog_V1.2.sh tmp\ip_conn.sh tmp\ip_keepalive.sh tmp\nagios使用手冊(cè).doc tmp\nmap_ping tmp\nrpe_install-1.3.sh tmp\one tmp\syn.sh tmp\zabbix_agentd_2.0.10_win_V1.2.bat tmp\zabbix_agentd_2.0.8_V1.3.sh tmp\工作內(nèi)容.doc
要列出子目錄中的文件,必須把子目錄包含在模式中。
import glob print 'Name explicitly:' for name in glob.glob('tmp/one/*'): print '\t', name print 'Name with wildcard:' for name in glob.glob('tmp/*/*'): print '\t', name
第一種情況顯示列出子目錄名,第二種情況則依賴一個(gè)通配符查找目錄。
>>> ================================ RESTART ================================ >>> Name explicitly: tmp/one\another.txt tmp/one\file.txt Name with wildcard: tmp\one\another.txt tmp\one\file.txt
單字節(jié)通配符
問號(hào)會(huì)匹配文件名中該位置的單個(gè)字符。
import glob for name in glob.glob('tmp/chec?_traffic.sh'): print name
>>> ================================ RESTART ================================ >>> tmp\check_traffic.sh
字符區(qū)間
使用字符區(qū)間([a-z]),可以匹配多個(gè)字符中的一個(gè)字符。
import glob for name in glob.glob('tmp/one/[a-z]*'): print name
區(qū)間可以匹配所有小寫字母。
>>> ================================ RESTART ================================ >>> tmp/one\another.txt tmp/one\file.txt
相關(guān)文章
Python自然語(yǔ)言處理庫(kù)之NLTK庫(kù)初級(jí)教程
NLTK(Natural Language Toolkit)是一個(gè)Python庫(kù),用于實(shí)現(xiàn)自然語(yǔ)言處理(NLP)的許多任務(wù),NLTK包括一些有用的工具和資源,如文本語(yǔ)料庫(kù)、詞性標(biāo)注器、語(yǔ)法分析器等,在這篇初級(jí)教程中,我們將了解NLTK的基礎(chǔ)功能,需要的朋友可以參考下2023-08-08python遠(yuǎn)程調(diào)用rpc模塊xmlrpclib的方法
今天小編就為大家分享一篇python遠(yuǎn)程調(diào)用rpc模塊xmlrpclib的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-01-01Python和RabbitMQ進(jìn)行消息傳遞和處理方式
這篇文章主要介紹了Python和RabbitMQ進(jìn)行消息傳遞和處理方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07python使用正則表達(dá)式分析網(wǎng)頁(yè)中的圖片并進(jìn)行替換的方法
這篇文章主要介紹了python使用正則表達(dá)式分析網(wǎng)頁(yè)中的圖片并進(jìn)行替換的方法,涉及Python使用正則表達(dá)式的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03