git show:在检查过去提交的更改时排除目录

  • 本文关键字:排除 提交 show 过去 git git
  • 更新时间 :
  • 英文 :


我通常使用 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'

最新更新