我通常使用 git show
命令检查提交引入的更改。这很有效,除非我只对更改文件的子集中引入的更改感兴趣。
有没有像git show --exclude some/path
这样的东西可以开箱即用?
将@DavidN的评论翻译成答案,这就是你得到的(人们可能没有意识到"git log"和"git show"采用所有相同的选项):
git show -- . ':!some/path'
需要 git 1.9 或更高版本。
下面是一个示例,显示了它对 php github 存储库的使用:
git remote -v
origin https://github.com/php/php-src.git (fetch)
这是一个没有排除的"--name-only"git show:
git show -p -m --first-parent --name-only --oneline e231830f1683e
e231830 Merge branch 'PHP-5.6.18' into PHP-7.0.3
ext/phar/dirstream.c
ext/phar/tar.c
ext/phar/tests/bug71331.phpt
ext/phar/tests/bug71331.tar
ext/phar/tests/bug71354.phpt
ext/phar/tests/bug71354.tar
ext/phar/tests/bug71391.phpt
ext/phar/tests/bug71391.tar
ext/phar/tests/bug71488.phpt
ext/phar/tests/bug71488.tar
ext/standard/iptc.c
ext/standard/streamsfuncs.c
ext/standard/tests/file/stream_rfc2397_002.phpt
ext/standard/tests/network/socket_get_status_basic.phpt
ext/standard/tests/streams/bug71323.phpt
[etc...]
这里它不包括"ext/phar":
git show -p -m --first-parent --name-only --oneline e231830f1683e -- . ':!ext/phar'
e231830 Merge branch 'PHP-5.6.18' into PHP-7.0.3
ext/standard/iptc.c
ext/standard/streamsfuncs.c
ext/standard/tests/file/stream_rfc2397_002.phpt
ext/standard/tests/network/socket_get_status_basic.phpt
ext/standard/tests/streams/bug71323.phpt
[etc...]
如果您有多个文件夹要忽略
git show -- . ':!some/path' ':!some/other/path'