成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

python 統(tǒng)計指定文件夾下所有的文件數(shù)量,BFS方式

KavenFan / 2348人閱讀

摘要:統(tǒng)計指定文件夾下所有的文件數(shù)量本來一直是有這個需求,只是以前寫的是遞歸的方式處理,感覺對資源的占用不友好,而且的最大遞歸深度不超過,所以改了一下,這里用廣度優(yōu)先遍歷的方式實現(xiàn)。實測兩層共個文件夾,共的文件數(shù)量。

python 統(tǒng)計指定文件夾下所有的文件數(shù)量

本來一直是有這個需求,只是以前寫的是遞歸的方式處理,感覺對資源的占用不友好,而且python的最大遞歸深度不超過1000,所以改了一下,這里用廣度優(yōu)先遍歷的方式實現(xiàn)。
實測兩層共24個文件夾,共50w的文件數(shù)量。運行時間大概3秒。以下是代碼:

import os
import queue

def get_file_quantity(folder: str) -> int:
    """BFS獲取文件夾下文件的總數(shù)量"""
    # 判斷初始文件夾
    assert os.path.isdir(folder), "請輸入有效的文件夾參數(shù)"
    file_quantity = 0                       # 初始化文件數(shù)量
    folder_path_queue = queue.Queue()
    folder_path_queue.put_nowait(folder)    # 初始化隊列的值
    # 處理隊列里的文件夾
    while not folder_path_queue.empty():
        folder = folder_path_queue.get_nowait()
        file_folder_list = list(map(lambda bar: os.path.join(folder, bar), os.listdir(folder)))
        folder_list = list(filter(lambda bar: os.path.isdir(bar), file_folder_list))
        for folder_path in folder_list:
            folder_path_queue.put_nowait(folder_path)
        temp_file_count = len(file_folder_list) - len(folder_list)
        file_quantity += temp_file_count
    return file_quantity
    
if __name__ == "__main__":
    file_quantity = get_file_quantity(r"/home")
    print(f"文件總數(shù)是: {file_quantity}")
思路

這里主要是使用了隊列,就是普通的BFS的思路

這里稍微改一下folder_list = list(filter(lambda bar: os.path.isdir(bar), file_folder_list))里的的lambda函數(shù)就可以實現(xiàn)判斷對文件名的各種判斷操作,這里函數(shù)功能的實現(xiàn)就完全取決于自己的腦洞了!

附上一個改編版: 查看包含特定后綴的文件的數(shù)量

改編版: 查看包含特定后綴的文件的數(shù)量
import os
import queue

def filter_extension(filename: str, extension: str) -> bool:
    """判斷文件路徑名的后綴是否和給定的后綴字符串相同
    只是單純的字符串判斷
    """
    basename_and_extension = filename.split(".")
    return (basename_and_extension[-1] == extension) and (len(basename_and_extension) >= 2)

def get_file_quantity(folder: str, extension: str) -> int:
    """BFS獲取文件夾下文件的總數(shù)量"""
    # 判斷初始文件夾
    assert os.path.isdir(folder), "請輸入有效的文件夾參數(shù)"
    assert isinstance(extension, str), "請輸入有效的文件后綴名"
    file_quantity = 0                       # 初始化文件數(shù)量
    folder_path_queue = queue.Queue()
    folder_path_queue.put_nowait(folder)    # 初始化隊列的值
    # 處理隊列里的文件夾
    while not folder_path_queue.empty():
        folder = folder_path_queue.get_nowait()
        file_folder_list = list(map(lambda bar: os.path.join(folder, bar), os.listdir(folder)))
        folder_list = list(filter(lambda bar: os.path.isdir(bar), file_folder_list))
        file_list = list(filter(lambda bar: os.path.isfile(bar), file_folder_list))
        match_extension_list = list(filter(lambda bar: filter_extension(bar, extension), file_list))
        for folder_path in folder_list:
            folder_path_queue.put_nowait(folder_path)
        temp_file_count = len(match_extension_list)
        file_quantity += temp_file_count
    return file_quantity
if __name__ == "__main__":
    extension = "py"
    file_quantity = get_file_quantity(r"/home", extension)
    print(f"包含后綴 {extension } 的文件的數(shù)量: {file_quantity}")

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/43744.html

相關文章

  • 自制小工具大大加速MySQL SQL語句優(yōu)化(附源碼)

    摘要:如果語句中使用了子查詢集合操作臨時表等情況,會給列帶來很大的復雜性。會遞歸執(zhí)行這些子查詢,把結果放在臨時表里。查詢優(yōu)化器從中所選擇使用的索引。該字段顯示了查詢優(yōu)化器通過系統(tǒng)收集的統(tǒng)計信息估算出來的結果集記錄條數(shù)。 引言 優(yōu)化SQL,是DBA常見的工作之一。如何高效、快速地優(yōu)化一條語句,是每個DBA經(jīng)常要面對的一個問題。在日常的優(yōu)化工作中,我發(fā)現(xiàn)有很多操作是在優(yōu)化過程中必不可少的步驟。然...

    Hujiawei 評論0 收藏0
  • PHP面試:常見查找算法一篇說透

    摘要:我們現(xiàn)在來看二分搜索算法的兩種變形插值搜索和指數(shù)搜索。插值搜索是對二分搜索算法的改進,插值搜索可以基于搜索的值選擇到達不同的位置。 預警 在本篇文章中,將為各位老鐵介紹不同的搜索算法以及它們的復雜度。因為力求通俗易懂,所以篇幅可能較長,大伙可以先Mark下來,每天抽時間看一點理解一點。本文配套的Github Repo,歡迎各位老鐵star,會一直更新的。 開篇 和排序類似,搜索或者叫做...

    付永剛 評論0 收藏0
  • Python腳本制作獲得fasta文件單編碼序列信息內容完成

      這篇文章主要為大家介紹了Python腳本提取fasta文件單序列信息實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪  此篇文章關鍵給大家介紹了Python腳本制作獲得fasta文件單編碼序列信息內容完成實例,感興趣的小伙伴可以參考借鑒一下,希望可以有一定的幫助,祝愿大家多多的發(fā)展,盡早漲薪  Python腳本制作編寫  應用Python對fasta格式編碼...

    89542767 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<