如何利用Python 快速找到最大文件
現(xiàn)在的電腦差不多都是固態(tài)硬盤(pán)了,速度很快,但容量不會(huì)太大,經(jīng)常會(huì)出現(xiàn)磁盤(pán)空間不足的情況,怎么辦,刪除那些不重要的最大的文件是最有效的辦法。
那么如何用找到最大的文件呢?比如說(shuō)找到最大的前 10 個(gè)文件?
思路:我們遍歷目錄,將文件路徑和文件大小作為生成器返回,然后插入大小為 10 的大頂堆,最后將大頂堆的內(nèi)容打印即可。
借助 Python,代碼很簡(jiǎn)潔:
import os import time from os.path import join, getsize from heapq import nlargest def walk_files_and_sizes(start_at: str): for root, _, files in os.walk(start_at): for file in files: path = join(root, file) try: size = getsize(path) # bytes yield path, size except OSError: continue def largest_files(n: int, start_at: str) -> None: MB = 1024 * 1024 largest = nlargest(n, walk_files_and_sizes(start_at), key=lambda x: x[1]) for path, size in largest: print(f'{size//MB} MB {path}') if __name__ == '__main__': start = time.perf_counter() largest_files(10, "/Users/aaron/") elapsed = time.perf_counter() - start print(f'{elapsed} seconds elapsed')
我在自己電腦上跑了下,200 GB 左右的目錄,123 秒就跑完了:
接下來(lái)刪除不需要的文件就可以了。
如果是 Windows 系統(tǒng)也是可以的:
largest_files(10, "C:/Users/xxx/")
到此這篇關(guān)于如何利用Python 快速找到最大文件的文章就介紹到這了,更多相關(guān)Python 快速找最大文件內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!
版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。