是否有一个选项来限制git差异到一个给定的文件扩展名集?
当前回答
Git diff只会显示非暂存文件中的差异。
我发现这个问题是因为我想从git diff中排除.info文件,我通过git add *.info来实现这一点,这减少了剩下的文件。
其他回答
是的,如果你确保git扩展一个glob而不是你的shell,那么它将在任何级别匹配,所以像这样的东西(引号很重要)应该工作得很好。
git diff -- '*.c' '*.h'
上面的答案似乎都不适合我在git bash下的Windows。我不确定这是否是一个版本的事情(我使用1.8.4)或Windows/bash的事情;此外,在我的情况下,我想区分两个分支,其中每个分支都有其他分支中不存在的额外文件(因此“查找”基于的是疏忽)。
不管怎样,这对我来说是有效的(在我的例子中,寻找python文件之间的差异):
git diff branch1 branch2 -- `git diff --summary branch1 branch2 | egrep '\.py$' | cut -d ' ' -f 5`
Git diff只会显示非暂存文件中的差异。
我发现这个问题是因为我想从git diff中排除.info文件,我通过git add *.info来实现这一点,这减少了剩下的文件。
为了递归地包括文件(包括当前目录),这对我来说是有效的:
git diff -- '***.py'
对于简单的文件模式,这似乎是可行的:
$ git ls-files -zm '*.txt' | xargs --null git diff
空格安全,你也可以有多个扩展:
$ git ls-files -zm '*.h|*.c|*.cpp' | xargs --null git diff
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别