python实现MD5进行文件去重的示例代码


Posted in Python onJuly 09, 2021
目录
  • 前言
  • 工作原理
  • 代码

 

前言

工作中偶尔会遇到文件去重的事情,收到一大堆文件,名称各不相同,分析文件的时候发现有不少重复的文件,导致工作效率低下,那么,这里就写了一个python脚本实现文件去重功能

 

工作原理

脚本会检查你给出的文件路径下的所有文件,然后计算每个文件的MD5值,并将其加入到一个列表中。

  • 如果某文件的MD5值不在列表中,就认定其是我们需要的文件,脚本会在桌面新建一个名为“去重结果”的文件夹,并将其复制到里面去。
  • 如果某文件的MD5值在列表中,就认定其不是我们需要的文件,不对其做任何处理。
  • 代码可以直接运行,无需做任何修改(除了安装可能缺少的库文件)

 

代码

import os
import shutil
import hashlib


# 对文件去重
# 计算每个文件的md5值,据此进行去重
def only_one(test_path):
    md5_list = []
    count = 0
    for current_folder, list_folders, files in os.walk(test_path):
        for file in files:
            file_path = current_folder + '\\' + file  # 获取每个文件的路径
            f = open(file_path, 'rb')  # 开始计算每个文件的md5值
            md5obj = hashlib.md5()
            md5obj.update(f.read())
            get_hash = md5obj.hexdigest()
            f.close()
            md5_value = str(get_hash).upper()
            # 开始去重
            if md5_value in md5_list:  # 如果这个文件的md5值曾经出现过,就不对它做任何处理
                count += 1
                print('\033[31m[-] 发现重复文件:\033[0m' + str(file))
            else:
                md5_list.append(md5_value)  # 如果这个文件的md5值不存在列表中,就添加进列表中
                shutil.copy(file_path, path1)
    print('\033[31m[-] 共发现重复文件:{}个\033[0m'.format(count))


if __name__ == '__main__':
    print('\033[4;33m[+] 此脚本会检查指定路径下的所有文件,通过计算文件的MD5值进行去重\033[0m')
    print('\033[4;33m[+] 去重后的文件会复制到桌面新文件夹中,源文件不会丢失\033[0m')
    path = input('\033[34m[+] 请输入文件夹地址:\033[0m')
    os.chdir(path)

    # path1 用来存放所有的去重结果
    desktop_path = os.path.join(os.path.expanduser("~"), 'Desktop')  # 获取桌面路径
    path1 = os.path.join(desktop_path, '去重结果')
    os.makedirs(path1)

    only_one(path)
    print('\033[32m[-] 现有非重复文件共计:{}个\033[0m'.format(len(os.listdir(path1))))

python实现MD5进行文件去重的示例代码

到此这篇关于python实现MD5进行文件去重的示例代码的文章就介绍到这了,更多相关python MD5文件去重内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python开发WebService系列教程之REST,web.py,eurasia,Django
Jun 30 Python
用Python脚本来删除指定容量以上的文件的教程
May 04 Python
使用Python脚本将Bing的每日图片作为桌面的教程
May 04 Python
使用PIL(Python-Imaging)反转图像的颜色方法
Jan 24 Python
Python Pandas实现数据分组求平均值并填充nan的示例
Jul 04 Python
Python对接六大主流数据库(只需三步)
Jul 31 Python
Python文件读写w+和r+区别解析
Mar 26 Python
Python Django中的STATIC_URL 设置和使用方式
Mar 27 Python
Jupyter notebook无法导入第三方模块的解决方式
Apr 15 Python
django rest framework 过滤时间操作
Jul 12 Python
Python基础之函数嵌套知识总结
May 23 Python
PYTHON基于Pyecharts绘制常见的直角坐标系图表
Apr 28 Python
深入浅析python3 依赖倒置原则(示例代码)
Jul 09 #Python
Python中Selenium对Cookie的操作方法
Python常用配置文件ini、json、yaml读写总结
图文详解matlab原始处理图像几何变换
Django中session进行权限管理的使用
python利用pandas分析学生期末成绩实例代码
使用pandas生成/读取csv文件的方法实例
You might like
图象函数中的中文显示
2006/10/09 PHP
PHP新手上路(二)
2006/10/09 PHP
Thinkphp3.2.3分页使用实例解析
2016/07/28 PHP
Yii框架 session 数据库存储操作方法示例
2019/11/18 PHP
JS 页面内容搜索,类似于 Ctrl+F功能的实现代码
2007/08/13 Javascript
document.designMode的功能与使用方法介绍
2007/11/22 Javascript
jQuery中live方法的重复绑定说明
2011/10/21 Javascript
jquery实现控制表格行高亮实例
2013/06/05 Javascript
28个常用JavaScript方法集锦
2015/01/14 Javascript
PHP和NodeJs开发的应用如何共用Session
2015/04/16 NodeJs
js中不同的height, top的区别对比
2015/09/24 Javascript
JQuery插件Marquee.js实现无缝滚动效果
2016/04/26 Javascript
jQuery 插件实现随机自由弹跳气泡样式
2017/01/12 Javascript
Vue 2.x教程之基础API
2017/03/06 Javascript
Vue学习之路之登录注册实例代码
2017/07/06 Javascript
JS点击图片弹出文件选择框并覆盖原图功能的实现代码
2017/08/25 Javascript
javascript基于牛顿迭代法实现求浮点数的平方根【递归原理】
2017/09/28 Javascript
vue.js 嵌套循环、if判断、动态删除的实例
2018/03/07 Javascript
VUE2.0中Jsonp的使用方法
2018/05/22 Javascript
微信小程序实现Session功能及无法获取session问题的解决方法
2019/05/07 Javascript
Vue.js中Line第三方登录api的实现代码
2020/06/29 Javascript
OpenLayer学习之自定义测量控件
2020/09/28 Javascript
原生JS实现pc端轮播图效果
2020/12/21 Javascript
用Python实现协同过滤的教程
2015/04/08 Python
Python 安装setuptools和pip工具操作方法(必看)
2017/05/22 Python
Python 从列表中取值和取索引的方法
2018/12/25 Python
解决Python3 被PHP程序调用执行返回乱码的问题
2019/02/16 Python
Django REST framework 视图和路由详解
2019/07/19 Python
Tomcat的缺省是多少,怎么修改
2014/04/09 面试题
《童趣》教学反思
2014/02/19 职场文书
《美丽的黄昏》教学反思
2014/02/28 职场文书
酒店开业庆典主持词
2014/03/21 职场文书
社区志愿者培训方案
2014/06/10 职场文书
演讲稿开场白台词
2014/08/25 职场文书
MySQL 数据丢失排查案例
2021/05/08 MySQL
Python时间操作之pytz模块使用详解
2022/06/14 Python