您当前的位置:首页 > IT编程 > python
| C语言 | Java | VB | VC | python | Android | TensorFlow | C++ | oracle | 学术与代码 | cnn卷积神经网络 | gnn | 图像修复 | Keras | 数据集 | Neo4j | 自然语言处理 | 深度学习 | 医学CAD | 医学影像 | 超参数 | pointnet | pytorch | 异常检测 | Transformers | 情感分类 | 知识图谱 |

自学教程:如何利用Python 快速找到最大文件

51自学网 2022-02-21 10:49:03
  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 秒就跑完了:

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

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

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

到此这篇关于如何利用Python 快速找到最大文件的文章就介绍到这了,更多相关Python 快速找最大文件内容请搜索51zixue.net以前的文章或继续浏览下面的相关文章希望大家以后多多支持51zixue.net!


Python 详解爬取并统计CSDN全站热榜标题关键词词频流程
Python 详解通过Scrapy框架实现爬取CSDN全站热榜标题热词流程
万事OK自学网:51自学网_软件自学网_CAD自学网自学excel、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。