网络编程
位置:首页>> 网络编程>> Python编程>> 如何利用Python 快速找到最大文件

如何利用Python 快速找到最大文件

作者:somenzz  发布时间:2021-08-06 23:22:47 

标签:Python,最大文件

如何利用Python 快速找到最大文件

现在的电脑差不多都是固态硬盘了,速度很快,但容量不会太大,经常会出现磁盘空间不足的情况,怎么办,删除那些不重要的最大的文件是最有效的办法。

那么如何用找到最大的文件呢?比如说找到最大的前 10 个文件?

思路:我们遍历目录,将文件路径和文件大小作为生成器返回,然后插入大小为 10 的大顶堆,最后将大顶堆的内容打印即可。

借助 Python,代码很简洁:


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 秒就跑完了:

如何利用Python 快速找到最大文件

接下来删除不需要的文件就可以了。

如果是 Windows 系统也是可以的:


largest_files(10, "C:/Users/xxx/")

来源:https://developer.51cto.com/art/202111/689052.htm

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com