Answers:
对于已更改文件的完整路径名:
git log --name-only
有关更改文件的完整路径名和状态:
git log --name-status
对于缩写的路径名和已更改文件的diffstat:
git log --stat
还有更多选择,请查阅docs。
git log --numstat
。请参阅git help log
以获取更多选项。
git log --name-only --oneline
也是很漂亮的-提交的颜色是一行,每行一个文件。stackoverflow.com/a/14227496/1995714
git log --name-status --find-renames
它来显示重命名的文件,而不是添加或删除。
--stat
缩写为长路径;宽度是可配置的,但是包裹的直方图更难阅读。其他格式(如--numstat
始终打印完整路径)。
--numstat
自git 2.22.00起位于该手册页的第946行。这是一个很大更多的选择比大多数人所需要的。
注意:已弃用,请改用 git whatchanged
git log
鼓励新用户改用 git-log [1]。该
whatchanged
命令本质上与git-log [1]相同, 但是默认情况下显示原始格式diff输出并跳过合并。该命令的保留主要是出于历史原因;早在
git log
通过阅读Linux内核邮件列表而发明Git的许多人的手指中就受过训练来键入它。
您可以使用该命令git whatchanged --stat
来获取每次提交中已更改的文件的列表(以及提交消息)。
如果只想获取文件名而不提交其余的提交消息,则可以使用:
git log --name-only --pretty=format: <branch name>
然后可以将其扩展为使用包含文件名的各种选项:
git log --name-status --pretty=format: <branch name>
git log --stat --pretty=format: <branch name>
使用此方法时要注意的一件事是,输出中有些空白行必须忽略。如果要查看在本地分支上已更改但尚未推送到远程分支的文件,并且不能保证已从远程获取最新文件,则使用此功能很有用。 :
git log --name-only --pretty=format: my_local_branch --not origin/master
将显示本地分支上已更改但尚未合并到远程主机上的所有分支的所有文件。
git log --stat --pretty="format:" $branchName
。因此,例如 git log --stat --pretty="format:" $(git rev-parse --abbrev-ref HEAD)
。在执行此操作时,以下确切的咒语与我的目的有关:git log --name-only --pretty="format: " master..$(git rev-parse --abbrev-ref HEAD)
git diff --stat HEAD^!
显示上次提交(HEAD
)的更改的文件和添加/删除的行数。
在我看来,没有哪个命令可以获取仅包含文件名的简明输出,并且一次可以添加和删除多个提交的行数,因此我为此创建了自己的bash脚本:
#!/bin/bash
for ((i=0; i<=$1; i++))
do
sha1=`git log -1 --skip=$i --pretty=format:%H`
echo "HEAD~$i $sha1"
git diff --stat HEAD~$(($i+1)) HEAD~$i
done
被称为例如。./changed_files 99
以简洁的形式将更改从转换HEAD
为HEAD~99
。可以用管道输送。到less
。
git diff --stat HEAD..master
无法显示HEAD和master之间的区别吗?还是在2012年发布答案时不存在?
HEAD
master
这是使用具有五个简单提交的本地存储库。
‣ git log --name-only
commit ed080bc88b7bf0c5125e093a26549f3755f7ae74 (HEAD -> master)
Author: My Name <user@email.com>
Date: Mon Oct 21 15:46:04 2019 -0700
mv file4 to file5
file5
commit 5c4e8cfbe3554fe3d7d99b5ae4ba381fa1cdb328
Author: My Name <user@email.com>
Date: Mon Oct 21 15:36:32 2019 -0700
foo file1
really important to foo before the bar
file1
commit 1b6413400b5a6a96d062a7c13109e6325e081c85
Author: My Name <user@email.com>
Date: Mon Oct 21 15:34:37 2019 -0700
foobar file2, rm file3
file2
file3
commit e0dd02ce23977c782987a206236da5ab784543cc
Author: My Name <user@email.com>
Date: Mon Oct 21 15:33:05 2019 -0700
Add file4
file4
commit b58e85692f711d402bae4ca606d3d2262bb76cf1
Author: My Name <user@email.com>
Date: Mon Oct 21 15:32:41 2019 -0700
Added files
file1
file2
file3
‣ git log --name-status
commit ed080bc88b7bf0c5125e093a26549f3755f7ae74 (HEAD -> master)
Author: My Name <user@email.com>
Date: Mon Oct 21 15:46:04 2019 -0700
mv file4 to file5
R100 file4 file5
commit 5c4e8cfbe3554fe3d7d99b5ae4ba381fa1cdb328
Author: My Name <user@email.com>
Date: Mon Oct 21 15:36:32 2019 -0700
foo file1
really important to foo before the bar
M file1
commit 1b6413400b5a6a96d062a7c13109e6325e081c85
Author: My Name <user@email.com>
Date: Mon Oct 21 15:34:37 2019 -0700
foobar file2, rm file3
M file2
D file3
commit e0dd02ce23977c782987a206236da5ab784543cc
Author: My Name <user@email.com>
Date: Mon Oct 21 15:33:05 2019 -0700
Add file4
A file4
commit b58e85692f711d402bae4ca606d3d2262bb76cf1
Author: My Name <user@email.com>
Date: Mon Oct 21 15:32:41 2019 -0700
Added files
A file1
A file2
A file3
‣ git log --stat
commit ed080bc88b7bf0c5125e093a26549f3755f7ae74 (HEAD -> master)
Author: My Name <user@email.com>
Date: Mon Oct 21 15:46:04 2019 -0700
mv file4 to file5
file4 => file5 | 0
1 file changed, 0 insertions(+), 0 deletions(-)
commit 5c4e8cfbe3554fe3d7d99b5ae4ba381fa1cdb328
Author: My Name <user@email.com>
Date: Mon Oct 21 15:36:32 2019 -0700
foo file1
really important to foo before the bar
file1 | 3 +++
1 file changed, 3 insertions(+)
commit 1b6413400b5a6a96d062a7c13109e6325e081c85
Author: My Name <user@email.com>
Date: Mon Oct 21 15:34:37 2019 -0700
foobar file2, rm file3
file2 | 1 +
file3 | 0
2 files changed, 1 insertion(+)
commit e0dd02ce23977c782987a206236da5ab784543cc
Author: My Name <user@email.com>
Date: Mon Oct 21 15:33:05 2019 -0700
Add file4
file4 | 0
1 file changed, 0 insertions(+), 0 deletions(-)
commit b58e85692f711d402bae4ca606d3d2262bb76cf1
Author: My Name <user@email.com>
Date: Mon Oct 21 15:32:41 2019 -0700
Added files
file1 | 0
file2 | 0
file3 | 0
3 files changed, 0 insertions(+), 0 deletions(-)
‣ git log --name-only --oneline
ed080bc (HEAD -> master) mv file4 to file5
file5
5c4e8cf foo file1
file1
1b64134 foobar file2, rm file3
file2
file3
e0dd02c Add file4
file4
b58e856 Added files
file1
file2
file3
‣ git log --pretty=oneline --graph --name-status
* ed080bc88b7bf0c5125e093a26549f3755f7ae74 (HEAD -> master) mv file4 to file5
| R100 file4 file5
* 5c4e8cfbe3554fe3d7d99b5ae4ba381fa1cdb328 foo file1
| M file1
* 1b6413400b5a6a96d062a7c13109e6325e081c85 foobar file2, rm file3
| M file2
| D file3
* e0dd02ce23977c782987a206236da5ab784543cc Add file4
| A file4
* b58e85692f711d402bae4ca606d3d2262bb76cf1 Added files
A file1
A file2
A file3
‣ git diff-tree HEAD
ed080bc88b7bf0c5125e093a26549f3755f7ae74
:100644 000000 e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 0000000000000000000000000000000000000000 D file4
:000000 100644 0000000000000000000000000000000000000000 e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 A file5
‣ git log --stat --pretty=short --graph
* commit ed080bc88b7bf0c5125e093a26549f3755f7ae74 (HEAD -> master)
| Author: My Name <user@email.com>
|
| mv file4 to file5
|
| file4 => file5 | 0
| 1 file changed, 0 insertions(+), 0 deletions(-)
|
* commit 5c4e8cfbe3554fe3d7d99b5ae4ba381fa1cdb328
| Author: My Name <user@email.com>
|
| foo file1
|
| file1 | 3 +++
| 1 file changed, 3 insertions(+)
|
* commit 1b6413400b5a6a96d062a7c13109e6325e081c85
| Author: My Name <user@email.com>
|
| foobar file2, rm file3
|
| file2 | 1 +
| file3 | 0
| 2 files changed, 1 insertion(+)
|
* commit e0dd02ce23977c782987a206236da5ab784543cc
| Author: My Name <user@email.com>
|
| Add file4
|
| file4 | 0
| 1 file changed, 0 insertions(+), 0 deletions(-)
|
* commit b58e85692f711d402bae4ca606d3d2262bb76cf1
Author: My Name <user@email.com>
Added files
file1 | 0
file2 | 0
file3 | 0
3 files changed, 0 insertions(+), 0 deletions(-)
‣ git log --name-only --pretty=format:
file5
file1
file2
file3
file4
file1
file2
file3
‣ git log --name-status --pretty=format:
R100 file4 file5
M file1
M file2
D file3
A file4
A file1
A file2
A file3
‣ git diff --stat 'HEAD^!'
file4 => file5 | 0
1 file changed, 0 insertions(+), 0 deletions(-)
‣ git show
commit ed080bc88b7bf0c5125e093a26549f3755f7ae74 (HEAD -> master)
Author: My Name <user@email.com>
Date: Mon Oct 21 15:46:04 2019 -0700
mv file4 to file5
diff --git a/file4 b/file5
similarity index 100%
rename from file4
rename to file5
感谢@ CB-Bailey @ Peter-Suwara @Gaurav @ Omer-Dagan @xsor @Hazok @nrz @ptc
另一个有用的命令是git diff-tree <hash>
,哈希也可以是哈希范围(用<old>..<new>
符号表示)。输出示例:
$ git diff-tree HEAD
:040000 040000 8e09a be406 M myfile
字段是:
源模式,目标模式,源哈希,目标哈希,状态,文件名
状态是您期望的状态:D(已删除),A(已添加),M(已修改)等。有关完整说明,请参见手册页。
git log
不仅仅支持-v
这么多期望/想要的开关?</