我如何打印一份包含所有提交文件的简单列表?

尽管下面列出了这些文件,但它也包含了每个文件不需要的差异信息:

git show a303aa90779efdd2f6b9d90693e2cbbbe4613c1d

当前回答

如果要获取已更改文件的列表:

git diff-tree --no-commit-id --name-only -r <commit-ish>

如果要获取提交中所有文件的列表,可以使用

git ls-tree --name-only -r <commit-ish>

其他回答

还有gitwhatchanged,它比gitlog更低级

NAME
       git-whatchanged - Show logs with difference each commit introduces

它输出提交摘要,其中包含其下的文件列表及其模式,以及它们是否被添加(a)、删除(D)或修改(M);

$ git whatchanged f31a441398fb7834fde24c5b0c2974182a431363

会给出如下内容:

commit f31a441398fb7834fde24c5b0c2974182a431363
Author: xx <xx@xx.nl>
Date:   Tue Sep 29 17:23:22 2015 +0200

    added fb skd and XLForm

:000000 100644 0000000... 90a20d7... A  Pods/Bolts/Bolts/Common/BFCancellationToken.h
:000000 100644 0000000... b5006d0... A  Pods/Bolts/Bolts/Common/BFCancellationToken.m
:000000 100644 0000000... 3e7b711... A  Pods/Bolts/Bolts/Common/BFCancellationTokenRegistration.h
:000000 100644 0000000... 9c8a7ae... A  Pods/Bolts/Bolts/Common/BFCancellationTokenRegistration.m
:000000 100644 0000000... bd6e7a1... A  Pods/Bolts/Bolts/Common/BFCancellationTokenSource.h
:000000 100644 0000000... 947f725... A  Pods/Bolts/Bolts/Common/BFCancellationTokenSource.m
:000000 100644 0000000... cf7dcdf... A  Pods/Bolts/Bolts/Common/BFDefines.h
:000000 100644 0000000... 02af9ba... A  Pods/Bolts/Bolts/Common/BFExecutor.h
:000000 100644 0000000... 292e27c... A  Pods/Bolts/Bolts/Common/BFExecutor.m
:000000 100644 0000000... 827071d... A  Pods/Bolts/Bolts/Common/BFTask.h
...

我知道这个答案并不符合“没有无关信息”,但我仍然认为这个列表比文件名更有用。

列出提交中更改的文件:

git diff --name-only SHA1^ SHA1

这不会显示日志消息、额外的换行符或任何其他混乱。这适用于任何提交,而不仅仅是当前提交。

最简单的形式:

git show--stat(哈希)

这更容易记住,它将为您提供所需的所有信息。

如果确实只需要文件的名称,可以添加--name only选项。

git show--stat--仅名称(哈希)

最近,我需要列出两次提交之间所有更改的文件。所以我使用了这个(也是*nix特定的)命令

git show --pretty="format:" --name-only START_COMMIT..END_COMMIT | sort | uniq

或者正如Ethan指出的:

git diff --name-only START_COMMIT..END_COMMIT

使用--name状态还将包括每个文件旁边的更改(添加、修改、删除等):

git diff --name-status START_COMMIT..END_COMMIT

好的,有几种方法可以显示特定提交中的所有文件。。。

要减少信息并仅显示提交的文件的名称,只需添加--name only或--name状态标志。。。这些标志只显示了与以前提交不同的文件名。。。

因此,您可以只在gitdiff后面加--name,在<sha0><sha1>之后加两个提交散列。类似以下内容:

git diff --name-only 5f12f15 kag9f02

我还创建了下图,以显示在这些情况下需要执行的所有步骤: