我试图从Git diff中排除一个文件(db/ irrelevance .php),我已经尝试将一个文件放在db子目录中,名为.gitattributes,并使用行irrelevance .php -diff 我还尝试创建了一个名为.git/info/attributes的文件,其中包含db/无关的。php。

在所有情况下,db/ irrelevance .php文件都作为Git二进制补丁包含在diff中。我想要的是由diff命令忽略对该文件的更改。我做错了什么?


当前回答

你也可以使用patchutils程序集合的filterdiff程序来排除diff的某些部分。例如:

git diff | filterdiff -p 1 -x db/irrelevant.php

其他回答

在现有答案的基础上,如果你想排除一个文件模式,无论它在目录中的哪个位置,使用相应的git路径spec值**:

git diff -- ':!**/yarn.lock'

类似于本·鲁克斯的解决方案,但无论如何都是共享的:

git status --porcelain | grep -v $PATTERN_TO_EXCLUDE | awk '{print $2}' | xargs git diff

或者,如果更改已经在本地提交:

git diff --name-only origin/master | grep -v $PATTERN_TO_EXCLUDE | xargs git diff origin/master

例子:

git status --porcelain | grep -v docs | awk '{print $2}' | xargs git diff origin/master

git diff --name-only origin/master | grep -v docs | xargs git diff origin/master

你也可以使用patchutils程序集合的filterdiff程序来排除diff的某些部分。例如:

git diff | filterdiff -p 1 -x db/irrelevant.php

我的解决方案

git add .
git reset <list of files to ignore>
git diff --cached

我做以下事情:

git add *pattern_to_exclude*
git diff
git reset HEAD .

我知道这不是一个优雅的解决方案,它有时不能被使用(例如。如果你已经把东西准备好了),但它不需要输入复杂的命令就能完成任务