我试图从Git diff中排除一个文件(db/ irrelevance .php),我已经尝试将一个文件放在db子目录中,名为.gitattributes,并使用行irrelevance .php -diff 我还尝试创建了一个名为.git/info/attributes的文件,其中包含db/无关的。php。
在所有情况下,db/ irrelevance .php文件都作为Git二进制补丁包含在diff中。我想要的是由diff命令忽略对该文件的更改。我做错了什么?
我试图从Git diff中排除一个文件(db/ irrelevance .php),我已经尝试将一个文件放在db子目录中,名为.gitattributes,并使用行irrelevance .php -diff 我还尝试创建了一个名为.git/info/attributes的文件,其中包含db/无关的。php。
在所有情况下,db/ irrelevance .php文件都作为Git二进制补丁包含在diff中。我想要的是由diff命令忽略对该文件的更改。我做错了什么?
当前回答
相对于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或添加多个排除(空格分隔引号块)如果你愿意。
您可以使用no op命令设置一个自定义diff驱动程序,并将其分配给那些应该忽略的文件。
使用此命令创建一个特定于存储库的差异驱动程序
git config diff.nodiff.command /bin/true
或者是你所有的,全球回购。
(如果MacOS中不存在/bin/true,则可以使用/usr/bin/true或echo)。
然后,将新的diff驱动程序分配给.git/info/attributes文件中你想忽略的那些文件。
irrelevant.php diff=nodiff
如果这个状态应该与其他开发人员共享,你可以使用.gitattributes而不是.git/info/attributes,并与你的同事共享git config命令(通过文档文件或其他东西)。
你也可以使用patchutils程序集合的filterdiff程序来排除diff的某些部分。例如:
git diff | filterdiff -p 1 -x db/irrelevant.php
这很简单,你可以使用标准的unix命令排除你想要的,这些命令在git bash下甚至在windows环境下都是可用的。 下面的例子展示了如何排除pom.xml文件的diff,首先检查diff只对文件名进行master,然后使用'grep -v'排除你不想要的文件,然后使用prepared list再次运行diff来master:
git diff master `git diff --name-only master | grep -v pom.xml`
如果你想这样做只是为了直观地检查差异,一个可视化的差异工具(如Meld)会让你用一个容易记住的简短命令来做。
首先,设置一个差异工具(如果你还没有的话)。
$ git config --global diff.tool = meld
然后,您可以运行目录差异。
$ git difftool --dir-diff
您将能够在Meld(或您选择的工具)中浏览差异(按文件)。不要打开你想要忽略的文件。