我有两个文件,每个文件都有一个文件名的 md5 校验和。两者都在不同的文件夹中。当我粘贴这些文件时,我正在寻找一种机制来执行以下操作:
如果 $column 3 匹配 $column 6,则仅并排打印出这两个:
filename1 = md5_checksum filename2 = md5_checksum
filename3 = md5_checksum filename4 = md5_checksum
filename5 = md5_checksum filename6 = md5_checksum
希望的结果:
filename1 = md5_checksum filename6 = md5_checksum
所以想象(或测试)以下输出:
md5 directoryA/* > checkA ; md5 directoryB/* > checkB
paste checkA checkB
我想说:“查看 checkA,filename1 也在 checkB 中,尽管名称不同”(相同的校验和)
仅供参考,我尝试过的:
awk > SIMILAR 'NR==FNR{ _[$4]=$4 next}{print $0, _[$4,$4] }' checkA checkB
($4 是文件 checkA 和 checkB 上的字段)
这是我认为对我正在尝试做的事情的最佳解释。衷心感谢您如此迅速地回答:
# touch A/{fee,fie,foo,fum}
# touch B/{Bee,Bie,Boo,Bum}
# md5 B/* > checkB
# md5 A/* > checkA
# more checkA
MD5 (A/fee) = 2737b49252e2a4c0fe4c342e92b13285
MD5 (A/fie) = df8b712c4fe20a0df933819665770165
MD5 (A/foo) = 51ca4befb7cb5bd22766a33c73ffca5b
MD5 (A/fum) = a80b2c31cfc269e4aa2f48658b5349d9
# more checkB
# md5 B/*
MD5 (B/Bee) = b026324c6904b2a9cb4b88d6d61c81d1
MD5 (B/Bie) = 2737b49252e2a4c0fe4c342e92b13285
MD5 (B/Boo) = df8b712c4fe20a0df933819665770165
MD5 (B/Bum) = 51ca4befb7cb5bd22766a33c73ffca5b
如果我们在这里看到,A 中的文件 foo (A/foo) 类似于 B/Bum
我希望输出类似于:
A/foo B/Bum = 51ca4befb7cb5bd22766a33c73ffca5b
A/fee B/Bie = 2737b49252e2a4c0fe4c342e92b13285