利用Python怎么自动清理电脑内的重复文件

  介绍

今天就跟大家聊聊有关利用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怎么自动清理电脑内的重复文件有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注行业资讯频道,感谢大家的支持。

利用Python怎么自动清理电脑内的重复文件