#yyds干货盘点#python文件及目录的比较

时间:2022-10-30 07:27:17

filecmp文件及目录的比较


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


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 缓存。如果一个文件过快地修改,以至于超过底层文件系统记录修改时间的精度,那么该函数可能有助于比较该类文件。

-----------------------------------