问题
Is there an option to restrict git diff
to a given set of file extensions?
回答1:
Yes, if you ensure that git expands a glob rather than your shell then it will match at any level so something like this (quotes are important) should work fine.
git diff -- '*.c' '*.h'
回答2:
Either use your shell's globstar (which does a recursive search)1,2:
shopt -s globstar
git diff -- *.py **/*.py
or use find:
find -name '*.py' -print0 | xargs -0 git diff --
Both of these are special-names and whitespace proof. Although you might want to filter for directories having the .py extension :)
1 I like to do git diff -- {.,**}/*.py
usually
2 When globstar is enabled, git diff -- **/*.py
already includes ./*.py
. In Bash's manpage: 'If followed by a /, two adjacent *s will match only directories and subdirectories.'
回答3:
To include files recursively (including current dir) this worked for me:
git diff -- '***.py'
回答4:
For simple file patterns, this seems to work:
$ git ls-files -zm '*.txt' | xargs --null git diff
Whitespace safe, and you can have multiple extensions too:
$ git ls-files -zm '*.h|*.c|*.cpp' | xargs --null git diff
回答5:
Command line argument for extension.
git diff *.py
In the alternative, you can pipe find
into git diff
:
find . -name '*.py' -type f | git diff --
回答6:
As I tested on git version 2.18.0, we should write the file extension between double quotation. If u want find the last differences between local repository and the remote one, after pulling, you can write it like below:
git diff YourBranchName@{1} YourBranchName --name-only "*.YourFileExtionsion"
For example:
git diff master@{1} origin/master --name-only "*.cs"
回答7:
None of the answers above seem to work for me under git bash
on Windows. I am not sure if it is a version thing (I'm using 1.8.4) or Windows/bash thing; also, in my case, I wanted to diff two branches where each branch had additional files not present in the other branch (thus the 'find' based ones are remiss).
Anyway this worked for me (in my example, looking for a diff between python files):
git diff branch1 branch2 -- `git diff --summary branch1 branch2 | egrep '\.py$' | cut -d ' ' -f 5`
回答8:
git diff
will only show differences in unstaged files.
I found this question because I wanted to exclude .info
files from git diff
. I achieved this by staging it with git add *.info
, which reduces the files left.
回答9:
I wound up with this:
commit=<the_commit_hash_goes_here> && git diff --name-only $commit | grep -i Test | egrep -v '\.sql$' | xargs git diff $commit --
This shows diffs for the specified commit only if the filename contains the word 'test' (case insensitive) and does not end with .sql
, modify the pipeline as necessary for your case.
来源:https://stackoverflow.com/questions/8554776/how-to-filter-git-diff-based-on-file-extensions