比较bash中的两个文件

时间:2014-09-17 15:02:20

标签: string bash grep find compare

我有两个文件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

由于

4 个答案:

答案 0 :(得分:3)

使用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

答案 1 :(得分:2)

我想使用标准工具diffbasename提出解决方案:

while read filename
do
    basename "$filename"
done < tmp2.txt > tmp2.basenames.txt
diff -u tmp1.txt tmp2.basenames.txt

此解决方案的主要优点是简单。但是输出看起来会略有不同,区分tmp1.txt-),tmp2.txt+)或两者()中的文件:< / p>

--- 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

答案 2 :(得分:1)

Bash解决方案:

#!/bin/bash
while read file && a=$(grep -Fw "$file" tmp2.txt)
do
   echo "$(basename $a): $(dirname $a)"
done < tmp1.txt

答案 3 :(得分:0)

如果你不想使用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