[英]Compare two files in bash
我有两个文件tmp1.txt和tmp2.txt,tmp1.txt有
aaa.txt
bbb.txt
ccc.txt
ddd.txt
tmp2.txt具有
/tmp/test1/aaa.txt
/tmp/test1/aac.txt
/tmp/test2/bbb.txt
/tmp/test1/ccc.txt
我想检查tmp1.txt中的文件是否存在于tmp2.txt中,如果存在,则显示它具有哪个文件,因此显示与此类似的内容
aaa.txt: test1
bbb.txt: test2
ccc.txt: test1
谢谢
使用awk
:
awk -F/ 'FNR==NR {a[$1];next} $NF in a {print $NF ": " $(NF-1)}' tmp1.txt tmp2.txt
aaa.txt: test1
bbb.txt: test2
ccc.txt: test1
我想使用标准工具diff
和basename
提出一个解决方案:
while read filename
do
basename "$filename"
done < tmp2.txt > tmp2.basenames.txt
diff -u tmp1.txt tmp2.basenames.txt
该解决方案的主要优点是简单。 不过,输出看起来会有些不同,区别tmp1.txt
( -
), tmp2.txt
( +
)或两者( ):
--- tmp1.txt 2014-09-17 17:09:43.000000000 +0200
+++ tmp2.basenames.txt 2014-09-17 17:13:12.000000000 +0200
@@ -1,4 +1,4 @@
aaa.txt
+aac.txt
bbb.txt
ccc.txt
-ddd.txt
重击解决方案:
#!/bin/bash
while read file && a=$(grep -Fw "$file" tmp2.txt)
do
echo "$(basename $a): $(dirname $a)"
done < tmp1.txt
如果您不想使用awk,则有一些bash循环:
while read f; do
isFound="$(grep /$f tmp2.txt 2>/dev/null)"
if [ ! -z "$isFound" ]; then
theDir=$(echo "$isFound"|cut -d'/' -f3)
echo "$f: $theDir"
fi
done <tmp1.txt
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.