如何解决用 md5sum 比较 2 个文件的内容
我可以单独计算它们:
my_prompt$ md5sum file_1.sql
20f750ff1aa835965ec93bf36fd8cf22 file_1.sql
my_prompt$ md5sum file_2.sql
733d53913c366ee87b6ce677971be17e file_2.sql
但是想知道如何将其合并为单个比较计算。 我尝试了不同的方法都失败了:
my_prompt$ md5sum file_1.sql == md5sum file_2.sql
my_prompt$ `md5sum file_1.sql` == `md5sum file_2.sql`
my_prompt$ (md5sum file_1.sql) == (md5sum file_2.sql)
my_prompt$ `md5sum file_1.sql` -eq `md5sum file_2.sql`
我在这里错过了什么? 尝试跟随 Compare md5 sums in bash script 和 https://unix.stackexchange.com/questions/78338/a-simpler-way-of-comparing-md5-checksum 没有走运。
解决方法
您需要一个程序/内置程序来评估比较。通常您会使用 test
/[
/[[
来执行此操作。使用这些程序 -eq
比较十进制数。因此,请改用字符串比较 =
。
[[ "$(md5sum file_1.sql)" = "$(md5sum file_2.sql)" ]]
此命令的退出代码 $?
告诉您两个字符串是否相等。
但是,您可能希望改用 cmp
。这个程序直接比较文件,应该更快,因为它不需要计算任何东西,而且更安全,因为它不会像散列比较那样给出误报。
cmp file_1.sql file_2.sql
,
通过将文件名作为参数传递给 md5sum
命令,我们得到了类似的东西:
$ md5sum foo.json bar.json
07a9a5c765f5d861b506eabd02f5aa4b *foo.json
07a9a5c765f5d861b506eabd02f5aa4b *bar.json
因此,我们必须比较 md5sum
输出的第一列:
if [[ $(md5sum foo.json bar.json | awk '{print $1}' | uniq | wc -l) == 1 ]]
then
echo "Identical files"
else
echo "There are differences"
fi
如果我们需要返回码,我们可以使用 test
命令,如下所示:
test $(md5sum foo.json bar.json | awk '{print $1}' | uniq | wc -l) == 1
让我们分解命令:
$ md5sum foo.json bar.json
07a9a5c765f5d861b506eabd02f5aa4b *foo.json
07a9a5c765f5d861b506eabd02f5aa4b *bar.json
$ md5sum foo.json bar.json | awk '{print $1}'
07a9a5c765f5d861b506eabd02f5aa4b
07a9a5c765f5d861b506eabd02f5aa4b
$ md5sum foo.json bar.json | awk '{print $1}' | uniq
07a9a5c765f5d861b506eabd02f5aa4b
$ md5sum foo.json bar.json | awk '{print $1}' | uniq | wc -l
1
$ test $(md5sum foo.json bar.json | awk '{print $1}' | uniq | wc -l) == 1
$ echo $?
0
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。