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

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


当前回答

天哪,驱动程序和awk排除一个糟糕的文件?自从git 1.9以来,你可以:

git diff -- . ':(exclude)db/irrelevant.php' ':(exclude)db/irrelevant2.php'

(在Windows上,将单引号'替换为双引号'。)

啊,优雅!请参阅引用的答案和@torek的回答

其他回答

我的解决方案

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

我做以下事情:

git add *pattern_to_exclude*
git diff
git reset HEAD .

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

git diff remote/master..master --name-only -- ':!README.rst'

给我(git版本2.11.0)

fatal: There is nothing to exclude from by :(exclude) patterns.
Perhaps you forgot to add either ':/' or '.' ?
git diff remote/master..master --name-only -- './*' ':!README.rst'

工作得很好,来源:https://stackoverflow.com/a/30084612/5155484

相对于git根目录

Git diff接受一个可选的排除

git diff -- ":(exclude)thingToExclude"

您可能需要添加一些通配符

git diff -- ":(exclude)*/thingToExclude/*"

目标特定的文件类型

git diff -- ":(exclude)*/$1/*.png"

或者为您的dotfiles添加一个小脚本

例如.bash_profile或.zshrc

gde() {
    # git diff exclude files or folders 
    # usage: 
    # gde fileOrFolderNameToExclude
    git diff -- ":(exclude)*/$1/*"
}

简单的回答

git diff ':!db/irrelevant.php'

只是‘:!在你的diff命令后<path>'。diff命令可以像你喜欢的那样复杂,你可以使用通配符,如*.min.js或添加多个排除(空格分隔引号块)如果你愿意。