db/irrelevant.php
db
.gitattributes
irrelevant.php -diff
.git/info/attributes
在所有情况下,db/irrelevant.php文件都作为Git二进制补丁包含在diff中。我想要的是由diff命令忽略对该文件的更改。我做错了什么?
你也可以使用patchutils程序集合的filterdiff程序来排除diff的某些部分。例如:
git diff | filterdiff -p 1 -x db/irrelevant.php
您可以使用no op命令设置一个自定义diff驱动程序,并将其分配给那些应该忽略的文件。
创建一个特定于存储库的差异驱动程序
git config diff.nodiff.command /bin/true
或用于所有使用--global的回购。
--global
(如果MacOS中不存在/bin/true,则可以使用/usr/bin/true或echo)。
/bin/true
/usr/bin/true
echo
.git/info/attributes文件中的然后,将新的diff驱动程序分配给那些您希望忽略的文件。
irrelevant.php diff=nodiff
如果这个状态应该与其他开发人员共享,你可以使用.gitattributes而不是.git/info/attributes,并与你的同伴共享git config命令(通过文档文件或其他东西)。
git config
这个单行解决方案不需要其他utils/downloads:
git diff `git status -s |grep -v ^\ D |grep -v file/to/exclude.txt |cut -b4-`
其中file/to/exclude.txt当然是你想要排除的文件名。
file/to/exclude.txt
编辑:credit ksenzee用于修复破坏差异的已删除文件。
类似于本面粉糊的解决方案,但无论如何共享:
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
天哪,驱动程序和awk排除一个糟糕的文件?因为Git 1.9之类的你可以:
git diff -- . ':(exclude)db/irrelevant.php' ':(exclude)db/irrelevant2.php'
(在Windows上,将单引号'替换为双引号"。)
'
"
啊,优雅!参见引用的答案和详细信息这个答案 by @torek
这种方法比公认的答案更短。
git diff 987200fbfb 878cee40ba -- ':!*.cs'
有关不同的包含/排除可能性的更多信息,请阅读这是另一篇文章
如果你想这样做只是为了直观地检查diff,一个可视化的diff工具(如融合)会让你用一个容易记住的简短命令来做。
首先,设置一个差异工具(如果你还没有的话)。
$ git config --global diff.tool = meld
然后,您可以运行目录差异。
$ git difftool --dir-diff
您将能够在Meld(或您选择的工具)中浏览差异(按文件)。不要打开你想要忽略的文件。
KurzedMetal对我需要做的事情的非常好的回答,这是能够看到文件已更改,但不生成差异,这可能是巨大的,在我的情况下。
但我的一个同事提出了一个更简单的方法,对我来说很有效:
在git diff要忽略的文件所在的目录中添加.gitattributes文件,内容如下:
git diff
file-not-to-diff.bin -diff
那还是让git status "see"如果文件改变了。git diff也将"see"但是它不会生成diff. xml文件。
git status
diff
示例中文件的.bin扩展名是经过深思熟虑的。我确实意识到这是二进制文件git的默认行为,它不需要特殊处理.gitattributes。但在我的情况下,这些文件被git识别为文本文件和“文件”;效用,这就成功了。
.bin
git diff master `git diff --name-only master | grep -v pom.xml`
我做以下事情:
git add *pattern_to_exclude* git diff git reset HEAD .
我知道这不是一个优雅的解决方案,它有时不能被使用(例如。如果你已经把东西准备好了),但它不需要输入复杂的命令就能完成任务
git diff接受可选的exclude
git diff -- ":(exclude)thingToExclude"
git diff -- ":(exclude)*/thingToExclude/*"
git diff -- ":(exclude)*/$1/*.png"
.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这样的通配符,或者添加多个排除符(用空格分隔引号块)。
':!<path>'
*.min.js
在现有答案的基础上,如果你想排除一个文件模式,无论它在目录中的哪个位置,请使用**对应的git pathspec值:
**
git diff -- ':!**/yarn.lock'
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 add . git reset <list of files to ignore> git diff --cached