我想知道如何从我的Git diff中排除整个目录(在本例中是/spec)。我正在使用git diff命令为我们整个软件版本创建一个diff。然而,规格的更改与此过程无关,只会造成头痛。现在我知道我能做到

git diff previous_release..current_release app/

这将为app目录中的所有更改创建一个差异,但不会为lib/目录中的实例创建差异。有人知道怎么完成这个任务吗?谢谢!

编辑:我只是想说清楚,我知道我可以把所有目录的参数串在末尾,减去/spec。我希望有一种方法能够真正排除命令中的单个目录。


当前回答

您可以尝试为lib目录中的任何文件取消设置diff属性。 .gitattributes:

lib/* -diff

Racl101在评论中补充道:

再补充一点,对于那些想要限制特定类型文件的git diff输出的人,在特定的目录及其子目录中,比如所有由Webpack打包的.js文件生成的JavaScript,例如,你可以将这个添加到.gitattributes:

dist/js/**/*.js -diff

然后你不会在你的git diff输出中看到所有的噪音,它只是显示为:二进制文件…不同哪个更有帮助。

其他回答

如果你想在一个git diff中指定多个路径来排除,你只需要在最后添加额外的排除参数,例如从stats中排除vendor和bin目录中的所有内容:-

git diff --stat previous_release..current_release -- . ':!vendor' ':!bin'

您可以尝试为lib目录中的任何文件取消设置diff属性。 .gitattributes:

lib/* -diff

Racl101在评论中补充道:

再补充一点,对于那些想要限制特定类型文件的git diff输出的人,在特定的目录及其子目录中,比如所有由Webpack打包的.js文件生成的JavaScript,例如,你可以将这个添加到.gitattributes:

dist/js/**/*.js -diff

然后你不会在你的git diff输出中看到所有的噪音,它只是显示为:二进制文件…不同哪个更有帮助。

git diff app lib

假设你使用bash,并且你已经启用了扩展通配符(shop -s extglob),你可以从shell端处理它:

git diff previous_release current_release !(spec)

省得你列出所有其他事情。

或者,shell-agnostic:

git diff previous_release current_release --name-only | grep -v '^spec/' \
    | xargs git diff previous_release current_release --

您可以将其打包到一行shell脚本中,从而不必重新键入参数。

基于这个答案,你还可以使用:

git diff previous_release..current_release -- . ':!spec'

这是git的一个新特性,允许排除某些路径。它应该比各种shell程序更可靠。

我在这里发布这个问题是因为这个问题仍然是“git差异排除路径”的第一热门。

从Git 2.13 (Q2 2017)开始,你可以替换!^。后者不需要引用。所以你可以写成

git diff previous_release..current_release -- . :^spec