python:filecmp --- 文件及目录的比较

python:filecmp --- 文件及目录的比较


filecmp 模块定义了用于比较文件及目录的函数,并且可以选取多种关于时间和准确性的折衷方案。对于文件的比较,另见 difflib 模块。

filecmp 模块定义了如下函数:

filecmp.cmp(f1, f2, shallow=True)
比较名为 f1 和 f2 的文件,如果它们似乎相等则返回 True ,否则返回 False 。

如果 shallow 为真值且两个文件的 os.stat() 签名信息(文件类型、大小和修改时间)一致,则文件会被视为相同。

在其他情况下,如果文件大小或内容不同则它们会被视为不同。

需要注意,没有外部程序被该函数调用,这赋予了该函数可移植性与效率。

该函数会缓存过去的比较及其结果,且在文件的 os.stat() 信息变化后缓存条目失效。所有的缓存可以通过使用 clear_cache() 来清除。

filecmp.cmpfiles(dir1, dir2, common, shallow=True)
比较在两个目录 dir1 和 dir2 中,由 common 所确定名称的文件。

返回三组文件名列表: match, mismatch, errors 。 match 含有相匹配的文件, mismatch 含有那些不匹配的,然后 errors 列出那些未被比较文件的名称。如果文件不存在于两目录中的任一个,或者用户缺少读取它们的权限,又或者因为其他的一些原因而无法比较,那么这些文件将会被列在 errors 中。

参数 shallow 具有同 filecmp.cmp() 一致的含义与默认值。

例如, cmpfiles(‘a’, ‘b’, [‘c’, ‘d/e’]) 将会比较 a/c 与 b/c 以及 a/d/e 与 b/d/e 。 ‘c’ 和 ‘d/e’ 将会各自出现在返回的三个列表里的某一个列表中。

filecmp.clear_cache()
清除 filecmp 缓存。如果一个文件过快地修改,以至于超过底层文件系统记录修改时间的精度,那么该函数可能有助于比较该类文件。

3.4 新版功能.

dircmp 类
class filecmp.dircmp(a, b, ignore=None, hide=None)
创建一个用于比较目录 a 和 b 的新的目录比较对象。 ignore 是需要忽略的文件名列表,且默认为 filecmp.DEFAULT_IGNORES 。 hide 是需要隐藏的文件名列表,且默认为 [os.curdir, os.pardir] 。

dircmp 类如 filecmp.cmp() 中所描述的那样对文件进行 shallow 比较。

dircmp 类提供以下方法:

report()
将 a 与 b 之间的比较结果打印(到 sys.stdout )。

report_partial_closure()
打印 a 与 b 及共同直接子目录的比较结果。

report_full_closure()
打印 a 与 b 及共同子目录比较结果(递归地)。

dircmp 类提供了一些有趣的属性,用以得到关于参与比较的目录树的各种信息。

需要注意,通过 getattr() 钩子,所有的属性将会惰性求值,因此如果只使用那些计算简便的属性,将不会有速度损失。

left
目录 a 。

right
目录 b 。

left_list
经 hide 和 ignore 过滤,目录 a 中的文件与子目录。

right_list
经 hide 和 ignore 过滤,目录 b 中的文件与子目录。

common
同时存在于目录 a 和 b 中的文件和子目录。

left_only
仅在目录 a 中的文件和子目录。

right_only
仅在目录 b 中的文件和子目录。

common_dirs
同时存在于目录 a 和 b 中的子目录。

common_files
同时存在于目录 a 和 b 中的文件。

common_funny
在目录 a 和 b 中类型不同的名字,或者那些 os.stat() 报告错误的名字。

same_files
在目录 a 和 b 中,使用类的文件比较操作符判定相等的文件。

diff_files
在目录 a 和 b 中,根据类的文件比较操作符判定内容不等的文件。

funny_files
在目录 a 和 b 中无法比较的文件。

subdirs
一个将 common_dirs 中的名称映射到 dircmp 实例(或者 MyDirCmp 实例,如果该实例类型为 dircmp 的子类 MyDirCmp 的话)的字典。

在 3.10 版更改: 在之前版本中字典条目总是为 dircmp 实例。 现在条目将与 self 的类型相同,如果 self 为 dircmp 的子类的话。

filecmp.DEFAULT_IGNORES
3.4 新版功能.

默认被 dircmp 忽略的目录列表。

下面是一个简单的例子,使用 subdirs 属性递归搜索两个目录以显示公共差异文件:

>>>
from filecmp import dircmp
def print_diff_files(dcmp):
    for name in dcmp.diff_files:
        print("diff_file %s found in %s and %s" % (name, dcmp.left,
              dcmp.right))
    for sub_dcmp in dcmp.subdirs.values():
        print_diff_files(sub_dcmp)

dcmp = dircmp('dir1', 'dir2') 
print_diff_files(dcmp) 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一个天秤座的程序猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值