如何将dir1
和dir2
中的文件的存在与dir3
。
例如:
dir1 dir2 dir3
file1 file2 file1
file3 file4 file2
file5 file6 file3
file9 file5
file6
file7
和输出如下:
only in dir1: file9
only in dir2: file4
only in dir3: file7
编辑:
我希望使用命令行找到差异,此外,我正在使用CentOS 7。
我使用diff dir1 dir2
比较了两个目录,并且我发现diff3
比较了三个文件,但没有三个目录。
这条小线Unix命令可以为您做到这一点。但是,只有当您的文件和目录不包含空格时才有效:
find dir{1..3} -mindepth 1 -type f | tr '/' ' ' | sort -k2,2 | uniq -u -f 1 | sed -e 's/ /: /' -e 's/^/only in /'
查找首先列出了所有目录。根据您的需求调整它,您的DIRS实际上并不是Dir1,Dir2和Dir3。
比我们用空间替换路径的"/",因为uniq
只能通过空格确定字段。我们在第二个字段(文件)上排序。比我们仅打印第二个字段的唯一线条,跳过了第一个字段(-f 1)。比我们使用SED来很好地打印独特的路径。
另一个变体:
find dir*/ -type f | sort -t/ -k2 | uniq -u -s 4 | sort
dir1/file9
dir2/file4
dir3/file7
化妆品:
find dir*/ -type f | sort -t/ -k2 | uniq -u -s 4 | sort | sed 's/dir/Only in dir/g' | sed 's///: /g'
Only in dir1: file9
Only in dir2: file4
Only in dir3: file7
gnu awk:
$ awk 'BEGINFILE {
n=split(FILENAME,t,"/") # I should use gensub here too
f[t[n]]++ # count distinct filenames
p[t[n]]=gensub(//[^/]*$/,"",1,FILENAME) # store path (collisions dont matter)
}
END {
for(i in f) # all files encountered
if(f[i]==1) # look for singles
printf "only in %s: %sn", p[i], i # ... and output them
}' dir1/* dir2/* dir3/* # or dir[123]/*
输出:
only in dir1: file9
only in dir2: file4
only in dir3: file7
non-gnu awks:
$ for i in dir[123]/*
do echo $i
done |
awk -F/ ' {
t=$NF
f[t]++
sub(//[^/]*$/,"")
p[t]=$0
}
END {
for(i in f)
if(f[i]==1)
printf "only in %s: %sn", p[i], i
}'
MELD是一个很好的图形差异前端,它将向您显示文件的侧面列表。与Ubuntu软件中心安装融合:
sudo apt-get install meld
meld dir1 dir2 dir3
检查是否有帮助您
与尴尬找到:
find . -mindepth 2 -name '*' |
awk -F/ '
{
seen[$NF]++
path[$NF] = $(NF-1)
}
END {
for(i in seen) {
if(seen[i]==1)
print "only in "path[i] ": " i
}
}
'