今天就跟大家聊聊有关利用Python怎么自动清理电脑内的重复文件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。
主要涉及的知识点有:
- <李>
操作系统模块综合应用
李> <李>水珠模块综合应用
李> <李>利用filecmp模块比较两个文件
李>步骤分析
该程序实现的逻辑可以具化为:
遍历获取给定文件夹下的所有文件,然后通过嵌套循环两两比较文件是否相同,如果相同则删除后者。
实现问题的关键就变成了
如何判断两个文件是否相同?
在这里我们可以使用filecmp模块,来看看官方的介绍文档:
- <李>
filecmp。cmp (f1、f2、浅=True)
李> <李>比较名为f1和f2的文件,如果它们似乎相等则返回真,否则返回假
李> <李>如果浅为真,那么具有相同os.stat()签名的文件将会被认为是相等的。否,则将比较文件的内容。
李>所以可以这样使用
#,假设x和y两个文件是相同的 打印(filecmp.cmp (x, y)) #,真正的
解决了这个问题,我们就可以开始写代码了!
Python实现
导入需要的库并设置目标文件夹路径
import 操作系统 import 水珠 import filecmp dir_path =, " # 39; C: \ \ xxxx # 39;
接着遍历获取所有文件的绝对路径,我们可以利用一滴模块的通配符结合递归参数即可完成,框架如下:
for file 拷贝glob.glob(时间+ path & # 39;/* */* & # 39;,,递归=True): 通过才能
由于遍历获取每一个文件或者文件夹后,需要判断是否是文件,如果是文件则可能将绝对路径存放到列表中,这里需要再完成两个事情:
- <李>
首先创建一个空列表,后面用list.append (i)添加文件路径
李> <李>接着利用os.path.isfile (i)判断是否是文件,返回正确则执行添加元素的操作
李>具体代码如下
file_lst =, [] for 小姐:glob.glob拷贝(dir_path +, & # 39;/* */* & # 39;,,递归=True): if 才能os.path.isfile(我): ,,,file_lst.append (i)
上一步我们获取了目标文件夹下的所有文件路径,接下来就可以嵌套遍历这个路径列表,其中<代码> filecmp.cmp 代码>进行文件判断,<代码>操作系统。删除代码>进行文件删除
for x 拷贝file_lst: for 才能;y  file_lst:拷贝 ,,,if x !=, y: ,,,,,if filecmp.cmp (x, y): ,,,,,,,os.remove (y)
这里的代码已经实现了大致逻辑,但有一个细节需要考虑到:有可能循环到文件已经被前面的判断删除了,导致<代码> os.remove(文件)> 代码由于文件不存在而报错
因此,可以用os.path。存在对文件存在进行判断,如下所示:
for x 拷贝file_lst: for 才能;y  file_lst:拷贝 ,,,if x !=, y 以及os.path.exists (x),以及os.path.exists (y): ,,,,,if filecmp.cmp (x, y): ,,,,,,,os.remove (y)
这样,一个简易的文件去重小程序就完成了,完整代码如下:
import 操作系统 import 水珠 import filecmp 时间=dir_path " # 39; C: \ xxxx # 39; 时间=file_lst [] for 小姐:glob.glob拷贝(dir_path +, & # 39;/* */* & # 39;,,递归=True): if 才能os.path.isfile(我): ,,,file_lst.append(我) for x  file_lst拷贝: for 才能;y  file_lst:拷贝 ,,,if x !=, y 以及os.path.exists (x),以及os.path.exists (y): ,,,,,if filecmp.cmp (x, y): ,,,,,,,os.remove (y)
看完上述内容,你们对利用Python怎么自动清理电脑内的重复文件有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注行业资讯频道,感谢大家的支持。