我有两个文件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
由于
答案 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)
我想使用标准工具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
(+
)或两者()中的文件:< / 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