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

git diff previous_release..current_release app/

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

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


当前回答

假设你使用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脚本中,从而不必重新键入参数。

其他回答

假设你使用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脚本中,从而不必重新键入参数。

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

lib/* -diff

Racl101在评论中补充道:

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

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

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

Git diff现在接受自定义排除格式:Git diff——':(排除)lib/*'

如果你有很多重复的文件夹名称('/app', '/lib'等),要小心,因为这将排除相对于当前工作目录和git根目录的文件。

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

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

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

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

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

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