我试图找到一个目录中存在的文件,但不在另一个目录中,我尝试使用这个命令:

diff -q dir1 dir2

上面这个命令的问题是,它在dir1中找到了文件,但在dir2中没有找到,在dir2中找到了文件,但在dir1中没有找到,

我正在寻找dir1中的文件,而不是dir2中的文件。

下面是我的数据的一个小样本

dir1    dir2    dir3
1.txt   1.txt   1.txt
2.txt   3.txt   3.txt
5.txt   4.txt   5.txt
6.txt   7.txt   8.txt

我脑子里的另一个问题是,如何在一个命令中找到dir1中的文件,而不是dir2或dir3中的文件?


当前回答

这应该做的工作:

diff -rq dir1 dir2

选项解释(通过diff(1)手册页):

-r -递归比较找到的任何子目录。 -q -只输出文件是否不同。

其他回答

这应该做的工作:

diff -rq dir1 dir2

选项解释(通过diff(1)手册页):

-r -递归比较找到的任何子目录。 -q -只输出文件是否不同。

GNU grep可以使用-v选项反向搜索。这使得grep报告不匹配的行。这样就可以从dir1中的文件列表中删除dir2中的文件。

grep -v -F -x -f <(find dir2 -type f -printf '%P\n') <(find dir1 -type f -printf '%P\n')

选项-F -x告诉grep在整行上执行字符串搜索。

进行这种比较的一个好方法是使用find和md5sum,然后使用diff。

例子:

使用find列出目录中的所有文件,然后计算每个文件的md5散列,并将其输送到一个文件:

find /dir1/ -type f -exec md5sum {} \; > dir1.txt

对另一个目录执行相同的步骤:

find /dir2/ -type f -exec md5sum {} \; > dir2.txt

然后用"diff"比较结果两个文件:

diff dir1.txt dir2.txt

当要比较的两个目录不在同一台机器上,并且需要确保两个目录中的文件相等时,此策略非常有用。

完成这项工作的另一种好方法是使用git

git diff --no-index dir1/ dir2/

最好的问候!

这有点晚,但可能会帮助到一些人。不确定diff或rsync是否只输出像这样的裸格式的文件名。感谢plhn给出了我在下面扩展的很好的解决方案。

如果您只想要文件名,那么就很容易以干净的格式复制所需的文件,您可以使用find命令。

comm -23 <(find dir1 | sed 's/dir1/\//'| sort) <(find dir2 | sed 's/dir2/\//'| sort) | sed 's/^\//dir1/'

这假设dir1和dir2都在同一个父文件夹中。Sed只是删除了父文件夹,以便您可以进行比较。最后一个sed只是把dir1的名字放回去。

如果你只想要文件:

comm -23 <(find dir1 -type f | sed 's/dir1/\//'| sort) <(find dir2 -type f | sed 's/dir2/\//'| sort) | sed 's/^\//dir1/'

对于目录也是如此:

comm -23 <(find dir1 -type d | sed 's/dir1/\//'| sort) <(find dir2 -type d | sed 's/dir2/\//'| sort) | sed 's/^\//dir1/'

Meld (http://meldmerge.org/)在比较目录和其中的文件方面做得很好。