是否有一种方法可以列出更改特定文件的所有提交?


当前回答

要获得一个提交哈希列表,使用git rev-list:

 git rev-list HEAD <filename>

输出:

b7c4f0d7ebc3e4c61155c76b5ebc940e697600b1
e3920ac6c08a4502d1c27cea157750bd978b6443
ea62422870ea51ef21d1629420c6441927b0d3ea
4b1eb462b74c309053909ab83451e42a7239c0db
4df2b0b581e55f3d41381f035c0c2c9bd31ee98d

这意味着有五次提交涉及到该文件。它是按倒序排列的,所以列表中的第一个提交b7c4f0d7是最近的一个。

其他回答

gitk <path_to_filename>

假设已经安装了包“gitk”。

如果没有安装,请执行以下操作:

sudo apt-get install gitk

然后尝试上面的命令。它是Linux的…如果Linux用户需要GUI,它可能会对他们有所帮助。

如果你希望看到提交中对特定文件的所有更改(而不仅仅是对文件本身的更改),你可以传递——full-diff:

git log -p --full-diff [branch] -- <path>

正如jackrabb1t指出的那样,——follow更加健壮,因为它继续列出重命名/移动之外的历史记录。因此,如果你正在寻找一个当前不在同一路径上的文件,或者一个在多次提交中被重命名的文件,——follow将跟踪它。

如果你想可视化名称/路径的变化,这可能是一个更好的选择:

git log --follow --name-status -- <path>

但如果你想要一个更紧凑的清单,只列出重要的事情:

git log --follow --name-status --format='%H' -- <path>

甚至

git log --follow --name-only --format='%H' -- <path>

缺点是—follow只适用于单个文件。

——follow适用于特定的文件

git log --follow -- filename

与给出的其他解的区别

注意,其他解决方案包括git日志路径(没有——follow)。如果你想跟踪目录中的变化,但是当文件被重命名时(因此使用——follow filename),这种方法很方便。

如果你想通过文件名而不是文件路径来查找所有的提交,使用:

git log --all -- '*.wmv'