来源 | 早起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

由于遍历获取每一个文件或者文件夹后,需要判断是否是文件,如果是文件则可能将绝对路径存放到列表中,这里需要再完成两个事情:

  1. 首先创建一个空列表,后面用list.append(i)添加文件路径

  2. 接着利用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 代码自动清理电脑内重复文件,解放双手!相关推荐

  1. 10行Python代码自动清理电脑内重复文件,解放双手!

    前言 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」 主要涉及的知识点有: os模块综合应用 glob模块综合应用 利用file ...

  2. 10行Python代码自动清理电脑内重复文件,释放双手!

    给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」 主要涉及的知识点有: os模块综合应用glob模块综合应用利用filecmp模块比较两个文件步骤分析 该程序实现的逻辑 ...

  3. 10行Python代码自动清理电脑内重复文件

    给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除 主要涉及的知识点有: os模块综合应用 glob模块综合应用 利用filecmp模块比较两个文件 步骤分析 该程序实现的 ...

  4. 截取文件最后10行_10 行 Python 代码自动清理电脑内重复文件,解放双手

    来源 | 早起Python 头图 | 视觉中国 前言 大家好,又到了Python办公自动化系列. 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若 ...

  5. linux将所有文件生成lst_10行Python代码自动清理电脑内重复文件,解放双手!

    作者:陈熹 来源:早起Python 大家好,又到了Python办公自动化系列. 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」 ...

  6. python 判断文件夹是否存在 否则创建_10行Python代码自动清理电脑内重复文件,解放双手!...

    大家好,又到了Python办公自动化系列. 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用Python检查给定文件夹下有无文件重复,若存在重复则删除」 主要涉及的知识点有: os模块综合应 ...

  7. 10 行 Python 代码自动清理电脑重复文件,解放双手!

    作者 | 陈熹 来源 | 早起Python(ID:zaoqi-python) 前言 大家好,又到了 Python 办公自动化系列. 今天分享一个系统层面的自动化案例: 「给定一个文件夹,使用 Pyth ...

  8. python自动化--如何用10行Python代码调一个闹钟 #电脑调闹钟

    python自动化--如何用10行Python代码写一个闹钟 前言: 文末彩蛋--轻松一刻 更多关于Python的知识请加关注哟~~.若需联系博主请私信或者加博主联系方式:       QQ:1542 ...

  9. 10 行 Python 代码能实现哪些有趣功能?

    大家好,我是菜鸟哥 Python凭借其简洁的代码,赢得了许多开发者的喜爱.因此也就促使了更多开发者用Python开发新的模块,从而形成良性循环,Python可以凭借更加简短的代码实现许多有趣的操作.下 ...

最新文章

  1. 16-flutter-Swiper 插件的使用
  2. 白话Elasticsearch62-进阶篇之Highlighting高亮显示
  3. TF-A代码阅读: 双系统切换时是如何保存寄存器的(cpu_context介绍)
  4. ARVR编辑器V1.2.4曝光,原来好作品都是在这诞生的!
  5. 表单校验---struts2
  6. Windows Server 2012学习
  7. android自定义view流程,Android 自定义View--从源码理解View的绘制流程
  8. gohost -- go 开发的命令行hosts配置管理工具
  9. NAT穿越技术详细介绍
  10. kendoui实现单选多选汉字/拼音/简拼筛选过滤
  11. 第三篇——哈希值校验工具
  12. 2022西工大网络安全知识竞赛赛后回顾资料
  13. 入职培训分享——第二篇 知识产权篇
  14. adbdriver的安装
  15. Android Button控件字母大小写显示问题
  16. 『XXG JS』JavaScript 数组 - 查找
  17. 计算机考试照片识别,PS照片JPEGsnoop帮你鉴别
  18. 修复OutLook2007 pst 文件
  19. 复数和向量的函数运算
  20. tp5.1微信支付开发系列(一)

热门文章

  1. CHSBO2018游记
  2. mssql查询过去一段时间数据库中执行过的语句及执行效率
  3. loj 6083.「美团 CodeM 资格赛」数码
  4. iOS Coding项目片段记录(五)
  5. 网站的基本功能:RBAC
  6. 用ThreadLocal代替单例模式synchronized的使用
  7. LongListSelector 控件 在 wp7 和wp8中的不同之处
  8. 四种浏览器对 clientHeight、offsetHeight、scrollHeight、clientWidth、offsetWidth 和 scrollWidth 的解释差异...
  9. 《那些年啊,那些事——一个程序员的奋斗史》——65
  10. SESSION和COOKIE的使用