SVN的日志有一个“-v”模式,输出每次提交时更改的文件的文件名,如下所示:

jes5199$ svn log -v
------------------------------------------------------------------------
r1 |   jes5199 | 2007-01-03 14:39:41 -0800 (Wed, 03 Jan 2007) | 1 line
Changed paths:
   A /AUTHORS
   A /COPYING
   A /ChangeLog
   A /EVOLUTION
   A /INSTALL
   A /MacOSX

是否有一种快速的方法可以在Git中获得每次提交时更改的文件列表?


当前回答

我正在使用:

git diff-tree -v --name-status -r <commit-id>

它显示了非常相似的输出,如svn log -v

其他回答

我通常使用这些来获取日志:

$ git log --name-status --author='<Name of author>' --grep="<text from Commit message>"

$ git log --name-status --grep="<text from Commit message>"

我每天都用它来显示文件更改的历史:

git log --stat --pretty=short --graph

为了保持简短,在你的.gitconfig中添加一个别名:

git config --global alias.ls 'log --stat --pretty=short --graph'

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的更改。例如,它可以通过管道传输到更少的地方。

更改文件的完整路径名:

git log --name-only

更改文件的完整路径名称和状态:

git log --name-status

对于缩略路径名和已更改文件的diffstat:

git log --stat

还有更多的选择。查看文档。

注意:git whatchanged已弃用,请使用git log代替

鼓励新用户使用 git-log[1]。的 什么改变命令本质上是一样的 Git-log[1],但默认显示 原始格式差异输出和跳过合并。 保留该司令部主要是出于历史原因;许多人的手指 在Git日志发明之前,人们通过阅读来学习Git Linux内核邮件列表都训练打字。


您可以使用命令git whatchanged——stat来获得每次提交时更改的文件列表(以及提交消息)。

参考文献

https://git-scm.com/docs/git-whatchanged