我试图从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 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
其他回答
这个单行解决方案不需要其他utils/downloads:
git diff `git status -s |grep -v ^\ D |grep -v file/to/exclude.txt |cut -b4-`
当然,file/to/exclude.txt是您想要排除的文件的名称。
编辑:credit ksenzee修复被删除的文件打破差异。
你也可以使用patchutils程序集合的filterdiff程序来排除diff的某些部分。例如:
git diff | filterdiff -p 1 -x db/irrelevant.php
在现有答案的基础上,如果你想排除一个文件模式,无论它在目录中的哪个位置,使用相应的git路径spec值**:
git diff -- ':!**/yarn.lock'
天哪,驱动程序和awk排除一个糟糕的文件?自从git 1.9以来,你可以:
git diff -- . ':(exclude)db/irrelevant.php' ':(exclude)db/irrelevant2.php'
(在Windows上,将单引号'替换为双引号'。)
啊,优雅!请参阅引用的答案和@torek的回答
简单的回答
git diff ':!db/irrelevant.php'
只是‘:!在你的diff命令后<path>'。diff命令可以像你喜欢的那样复杂,你可以使用通配符,如*.min.js或添加多个排除(空格分隔引号块)如果你愿意。