10 行 Python 代码自动清理电脑内重复文件,解放双手!
来源 | 早起Python
头图 | 视觉中国
前言
大家好,又到了Python办公自动化系列。
今天分享一个系统层面的自动化案例:
「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」
主要涉及的知识点有:
os模块综合应用
glob模块综合应用
利用filecmp模块比较两个文件
步骤分析
该程序实现的逻辑可以具化为:
遍历获取给定文件夹下的所有文件,然后通过嵌套循环两两比较文件是否相同,如果相同则删除后者。
实现问题的关键就变成了????
如何判断两个文件是否相同?
在这里我们可以使用filecmp模块,来看看官方的介绍文档:
filecmp.cmp(f1, f2, shallow=True)
比较名为f1和f2的文件,如果它们似乎相等则返回True,否则返回False
如果shallow为真,那么具有相同os.stat()签名的文件将会被认为是相等的。否则,将比较文件的内容。
所以可以这样使用????
# 假设x和y两个文件是相同的print(filecmp.cmp(x, y))# True
解决了这个问题,我们就可以开始写代码了!
Python实现
导入需要的库并设置目标文件夹路径
import osimport globimport filecmp
dir_path = r'C:\\xxxx'
接着遍历获取所有文件的绝对路径,我们可以利用glob模块的通配符结合recursive参数即可完成,框架如下:
for file in glob.glob(path + '/**/*', recursive=True): pass
由于遍历获取每一个文件或者文件夹后,需要判断是否是文件,如果是文件则可能将绝对路径存放到列表中,这里需要再完成两个事情:
首先创建一个空列表,后面用list.append(i)添加文件路径
接着利用os.path.isfile(i)判断是否是文件,返回True则执行添加元素的操作
具体代码如下
file_lst = []
for i in glob.glob(dir_path + '/**/*', recursive=True): if os.path.isfile(i): file_lst.append(i)
上一步我们获取了目标文件夹下的所有文件路径,接下来就可以嵌套遍历这个路径列表,其中filecmp.cmp进行文件判断,os.remove进行文件删除
for x in file_lst: for y in file_lst: if x != y: if filecmp.cmp(x, y): os.remove(y)
这里的代码已经实现了大致逻辑,但有一个细节需要考虑到:有可能循环到文件已经被前面的判断删除了,导致os.remove(file)由于文件不存在而报错
因此,可以用os.path.exists对文件存在进行判断,如下所示:
for x in file_lst: for y in file_lst: if x != y and os.path.exists(x) and os.path.exists(y): if filecmp.cmp(x, y): os.remove(y)
这样,一个简易的文件去重小程序就完成了,完整代码如下:
import osimport globimport filecmp
dir_path = r'C:\xxxx'
file_lst = []
for i in glob.glob(dir_path + '/**/*', recursive=True): if os.path.isfile(i): file_lst.append(i)
for x in file_lst: for y in file_lst: if x != y and os.path.exists(x) and os.path.exists(y): if filecmp.cmp(x, y): os.remove(y)更多精彩推荐
☞遭遇 XSS 跨站脚本攻击?稳住,这些方法可保你渡劫 | 附代码、图解
☞融资 2000 万美元后,他竟将核心代码全开源,这……能行吗?☞赞!网红程序员 AI 修复多国古老街景视频
☞赠书 | 人工智能识万物:卷积神经网络的前世今生
☞MySQL 索引分析除了 EXPLAIN 还有什么方法?
☞医疗数字化:区块链或成最强辅助
点分享点点赞点在看
10 行 Python 代码自动清理电脑内重复文件,解放双手!相关推荐
- 10行Python代码自动清理电脑内重复文件,解放双手!
前言 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」 主要涉及的知识点有: os模块综合应用 glob模块综合应用 利用file ...
- 10行Python代码自动清理电脑内重复文件,释放双手!
给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」 主要涉及的知识点有: os模块综合应用glob模块综合应用利用filecmp模块比较两个文件步骤分析 该程序实现的逻辑 ...
- 10行Python代码自动清理电脑内重复文件
给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除 主要涉及的知识点有: os模块综合应用 glob模块综合应用 利用filecmp模块比较两个文件 步骤分析 该程序实现的 ...
- 截取文件最后10行_10 行 Python 代码自动清理电脑内重复文件,解放双手
来源 | 早起Python 头图 | 视觉中国 前言 大家好,又到了Python办公自动化系列. 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若 ...
- linux将所有文件生成lst_10行Python代码自动清理电脑内重复文件,解放双手!
作者:陈熹 来源:早起Python 大家好,又到了Python办公自动化系列. 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」 ...
- python 判断文件夹是否存在 否则创建_10行Python代码自动清理电脑内重复文件,解放双手!...
大家好,又到了Python办公自动化系列. 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」 主要涉及的知识点有: os模块综合应 ...
- 10 行 Python 代码自动清理电脑重复文件,解放双手!
作者 | 陈熹 来源 | 早起Python(ID:zaoqi-python) 前言 大家好,又到了 Python 办公自动化系列. 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用 Pyth ...
- python自动化--如何用10行Python代码调一个闹钟 #电脑调闹钟
python自动化--如何用10行Python代码写一个闹钟 前言: 文末彩蛋--轻松一刻 更多关于Python的知识请加关注哟~~.若需联系博主请私信或者加博主联系方式: QQ:1542 ...
- 10 行 Python 代码能实现哪些有趣功能?
大家好,我是菜鸟哥 Python凭借其简洁的代码,赢得了许多开发者的喜爱.因此也就促使了更多开发者用Python开发新的模块,从而形成良性循环,Python可以凭借更加简短的代码实现许多有趣的操作.下 ...
最新文章
- 16-flutter-Swiper 插件的使用
- 白话Elasticsearch62-进阶篇之Highlighting高亮显示
- TF-A代码阅读: 双系统切换时是如何保存寄存器的(cpu_context介绍)
- ARVR编辑器V1.2.4曝光,原来好作品都是在这诞生的!
- 表单校验---struts2
- Windows Server 2012学习
- android自定义view流程,Android 自定义View--从源码理解View的绘制流程
- gohost -- go 开发的命令行hosts配置管理工具
- NAT穿越技术详细介绍
- kendoui实现单选多选汉字/拼音/简拼筛选过滤
- 第三篇——哈希值校验工具
- 2022西工大网络安全知识竞赛赛后回顾资料
- 入职培训分享——第二篇 知识产权篇
- adbdriver的安装
- Android Button控件字母大小写显示问题
- 『XXG JS』JavaScript 数组 - 查找
- 计算机考试照片识别,PS照片JPEGsnoop帮你鉴别
- 修复OutLook2007 pst 文件
- 复数和向量的函数运算
- tp5.1微信支付开发系列(一)
热门文章
- CHSBO2018游记
- mssql查询过去一段时间数据库中执行过的语句及执行效率
- loj 6083.「美团 CodeM 资格赛」数码
- iOS Coding项目片段记录(五)
- 网站的基本功能:RBAC
- 用ThreadLocal代替单例模式synchronized的使用
- LongListSelector 控件 在 wp7 和wp8中的不同之处
- 四种浏览器对 clientHeight、offsetHeight、scrollHeight、clientWidth、offsetWidth 和 scrollWidth 的解释差异...
- 《那些年啊,那些事——一个程序员的奋斗史》——65
- SESSION和COOKIE的使用