亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python 如何查找特定類型文件

 更新時(shí)間:2020年08月17日 10:09:03   作者:Rocky0429  
這篇文章主要介紹了Python 如何定位特定類型文件,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下

寫在之前

今天的文章是介紹如何用 Python 去定位特定類型的文件,會(huì)講到用字符串匹配文件名定位特定文件以及順帶介紹一下遍歷目錄樹(shù)的函數(shù),通過(guò)今天的這一部分以及之前文章講到的文件獲取屬性的操作,可以做很多有意思的事情。

定位特定文件

定位特定的文件,可以使用 fnmatch 以及 glob 這兩個(gè)標(biāo)準(zhǔn)庫(kù),我們下面來(lái)分別看一下。

1. 使用 fnmatch 標(biāo)準(zhǔn)庫(kù)

一般的話我們想要查找特定類型的文件,可以通過(guò)字符串的前綴匹配和后綴匹配來(lái)查找,具體實(shí)例如下所示:

>>> import os
>>> [txt for txt in os.listdir('.') if txt.endswith('.txt')]
['b.txt', 'a.txt']

其實(shí)大部分的情況下這種用字符串匹配的方法來(lái)查找文件就足夠可以滿足需要,如果有些情況下需要更加靈活一點(diǎn)的字符串匹配,就可以使用 fnmatch 庫(kù),這是一個(gè)專門用來(lái)進(jìn)行文件名匹配的庫(kù),支持使用通配符來(lái)進(jìn)行文字匹配(比如'*','?'等)。

fnmatch 這個(gè)庫(kù)很簡(jiǎn)單,只有 4 個(gè)函數(shù):fnmatch,fnmatchcase,filter,translate:

  • fnmatch:判斷文件名是否符合特定的模式;
  • fnmatchcase:判斷文件名是否符合特定的模式(不區(qū)分大小寫);
  • filter:返回輸入列表中,符合特定模式的文件名列表;
  • translate:將通配符模式轉(zhuǎn)換成正則表達(dá)式。

上面 4 個(gè)最常用是它的同名函數(shù) fnmatch ,我的當(dāng)前目錄下有 4 個(gè)文件,分別是:a.txt,b.txt,c.py,test.py,下面我就用 fnmatch 函數(shù)來(lái)對(duì)當(dāng)前目錄下的這 4 個(gè)文件進(jìn)行匹配性測(cè)試,具體請(qǐng)看下面代碼:

>>> import os
>>> import fnmatch
>>> os.listdir('.')
['test.py', 'c.py', 'b.txt', 'a.txt']
>>> [txt for txt in os.listdir('.') if fnmatch.fnmatch(txt, '*.txt')]
['b.txt', 'a.txt']
>>> [file for file in os.listdir('.') if fnmatch.fnmatch(file, '[a-c]*')]
['c.py', 'b.txt', 'a.txt']
>>> [file for file in os.listdir('.') if fnmatch.fnmatch(file, '[!a-c]*')]
['test.py']

fnmatchcase 函數(shù)與 fnmatch 函數(shù)幾乎一樣,只是在匹配的時(shí)候會(huì)忽略大小寫字母;filter 函數(shù)與 fnmatch 比較類似,區(qū)別在于fnmatch 一次只對(duì)一個(gè)文件名匹配,而 filter 一次可以對(duì)多個(gè)文件名進(jìn)行匹配判斷,下面我們就再來(lái)看一下 filter 的用法:

>>> import os
>>> import fnmatch
>>> file = os.listdir('.')
>>> file
['test.py', 'c.py', 'b.txt', 'a.txt']
>>> fnmatch.filter(file, '[a-c]*')
['c.py', 'b.txt', 'a.txt']
>>> fnmatch.filter(file, '[!a-c]*')
['test.py']

2.使用 glob 定位

我們?cè)谏厦娼榻B的獲取特定類型的文件列表,首先是通過(guò) os.listdir 獲取全部的文件列表,然后通過(guò)字符串匹配或者使用 fnmatch 進(jìn)行文件名模式匹配來(lái)定位,習(xí)慣了 Python 的簡(jiǎn)潔優(yōu)雅,這多出來(lái)的一步總覺(jué)得哪里怪怪的,好在我現(xiàn)在知道了 glob。

glob 的作用相當(dāng)于 os.listdir + fnmatch 的組合,使用 glob 以后,就不需要用 os.listdir 獲取文件列表,直接通過(guò)模式匹配就可以解決了,具體操作如下所示:

>>> import glob
>>> glob.glob('*.txt')
['b.txt', 'a.txt']
>>> glob.glob('[a-c]*')
['c.py', 'b.txt', 'a.txt']
>>> glob.glob('[!a-c]*')
['test.py']

可以看到,Python 真的非常的靈活,光是定位目錄下特定的文件類型我就已經(jīng)介紹了 3 種方式,一般情況下就用字符串匹配就可以解決,如果需要更加靈活一點(diǎn)的的,可以使用 fnmatch 和 glob。

遍歷目錄樹(shù)

再上一節(jié)中我們都是查找某個(gè)目錄下的文件然后通過(guò)匹配去定位自己需要的文件類型。但是在實(shí)際的應(yīng)用過(guò)程中我們更可能遇到的是某個(gè)目錄及其子目錄下的所有文件。比如查找某個(gè)目錄及其子目錄下所有的 txt 文件等等,對(duì)于這類的需求,我們可以使用 os 模塊下的「walk」函數(shù)。walk 函數(shù)遍歷某個(gè)目錄及其子目錄,對(duì)于每一個(gè)目錄,walk 返回一個(gè)三元組,依次是「當(dāng)前目錄」,「當(dāng)前目錄下的子目錄」,「當(dāng)前目錄下的文件列表」。

下面我們來(lái)演示一下 os.walk 函數(shù)的用法,做一個(gè)小的練習(xí),來(lái)遍歷一下 /root/rocky0429 目錄及其子目錄下的所有 txt 和 圖片文件:

import os
import fnmatch

search = ['*.txt', '*.jpg', '*.jpeg']
res = []

for root, dirnames, filenames in os.walk(os.path.expanduser('~/rocky0429')):
  for extension in search:
    for filename in fnmatch.filter(filenames, extension):
      res.append(os.path.join(root,filename))

    print(res)

以上就是Python 如何查找特定類型文件的詳細(xì)內(nèi)容,更多關(guān)于python 查找文件的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • python+selenium+PhantomJS抓取網(wǎng)頁(yè)動(dòng)態(tài)加載內(nèi)容

    python+selenium+PhantomJS抓取網(wǎng)頁(yè)動(dòng)態(tài)加載內(nèi)容

    一般我們使用python的第三方庫(kù)requests及框架scrapy來(lái)爬取網(wǎng)上的資源,但是設(shè)計(jì)javascript渲染的頁(yè)面卻不能抓取,此 時(shí),我們使用web自動(dòng)化測(cè)試化工具Selenium+無(wú)界面瀏覽器PhantomJS來(lái)抓取javascript渲染的頁(yè)面,下面實(shí)現(xiàn)一個(gè)簡(jiǎn)單的爬取
    2020-02-02
  • Pycharm導(dǎo)入anaconda環(huán)境的教程圖解

    Pycharm導(dǎo)入anaconda環(huán)境的教程圖解

    這篇文章主要介紹了Pycharm導(dǎo)入anaconda環(huán)境的教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • python re模塊的高級(jí)用法詳解

    python re模塊的高級(jí)用法詳解

    這篇文章較詳細(xì)的給大家介紹了python re模塊的高級(jí)用法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2018-06-06
  • PyQt5-QDateEdit的簡(jiǎn)單使用操作

    PyQt5-QDateEdit的簡(jiǎn)單使用操作

    這篇文章主要介紹了PyQt5-QDateEdit的簡(jiǎn)單使用操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • python 隨機(jī)生成10位數(shù)密碼的實(shí)現(xiàn)代碼

    python 隨機(jī)生成10位數(shù)密碼的實(shí)現(xiàn)代碼

    這篇文章主要介紹了python 隨機(jī)生成10位數(shù)密碼的實(shí)現(xiàn)代碼,在文中給大家提到了生成隨機(jī)密碼要實(shí)現(xiàn)的功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-06-06
  • python實(shí)點(diǎn)云分割k-means(sklearn)詳解

    python實(shí)點(diǎn)云分割k-means(sklearn)詳解

    這篇文章主要為大家詳細(xì)介紹了Python實(shí)點(diǎn)云分割k-means,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • python imread讀取文件失敗的問(wèn)題及解決

    python imread讀取文件失敗的問(wèn)題及解決

    這篇文章主要介紹了python imread讀取文件失敗的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • python的scikit-learn將特征轉(zhuǎn)成one-hot特征的方法

    python的scikit-learn將特征轉(zhuǎn)成one-hot特征的方法

    今天小編就為大家分享一篇python的scikit-learn將特征轉(zhuǎn)成one-hot特征的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • 人工智能學(xué)習(xí)Pytorch數(shù)據(jù)集分割及動(dòng)量示例詳解

    人工智能學(xué)習(xí)Pytorch數(shù)據(jù)集分割及動(dòng)量示例詳解

    這篇文章主要為大家介紹了人工智能學(xué)習(xí)Pytorch數(shù)據(jù)集分割及動(dòng)量示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2021-11-11
  • python導(dǎo)出chrome書簽到markdown文件的實(shí)例代碼

    python導(dǎo)出chrome書簽到markdown文件的實(shí)例代碼

    python導(dǎo)出chrome書簽到markdown文件,主要就是解析chrome的bookmarks文件,然后拼接成markdown格式的字符串,最后輸出到文件即可。下面給大家分享實(shí)例代碼,需要的朋友參考下
    2017-12-12

最新評(píng)論