Git(7)-- 查看提交历史(git log 命令详解)

@


在提交了若干更新,又或者clone了某个项目之后,你也许想回顾下提交历史。 完成这个任务最简单而又有效的工具是 git log 命令。

1、git clone

我们使用一个非常简单的 “simplegit” 项目作为示例:

位置:https://github.com/schacon/simplegit-progit
Git(7)-- 查看提交历史(git log 命令详解)
运行下面的命令获取该项目:

git clone https://github.com/schacon/simplegit-progit
Git(7)-- 查看提交历史(git log 命令详解)

2、git log

当你在此项目中运行 git log 命令时,可以看到下面的输出:
Git(7)-- 查看提交历史(git log 命令详解)

Git(4)-- 如何退出 git log 和 git commit 状态

不传入任何参数的默认情况下,git log 会按时间先后顺序列出所有的提交,最近的更新排在最上面。 正如你所看到的,这个命令会列出每个提交的 SHA-1 校验和、作者的名字和电子邮件地址、提交时间以及提交说明。

git log 有许多选项可以帮助你搜寻你所要找的提交, 下面我们会介绍几个最常用的选项。

3、git log -p

其中一个比较有用的选项是 -p--patch ,它会显示每次提交所引入的差异(按 补丁 的格式输出)。 你也可以限制显示的日志条目数量,例如使用 -2 选项来只显示最近的两次提交:
Git(7)-- 查看提交历史(git log 命令详解)

该选项除了显示基本信息之外,还附带了每次提交的变化。 当进行代码审查,或者快速浏览某个搭档的提交所带来的变化的时候,这个参数就非常有用了。 你也可以为 git log 附带一系列的总结性选项。 比如你想看到每次提交的简略统计信息,可以使用 --stat 选项:

4、git log --stat

Git(7)-- 查看提交历史(git log 命令详解)
正如你所看到的,--stat 选项在每次提交的下面列出所有被修改过的文件、有多少文件被修改了以及被修改过的文件的哪些行被移除或是添加了。 在每次提交的最后还有一个总结。

5、git log --pretty=oneline

另一个非常有用的选项是 --pretty。 这个选项可以使用不同于默认格式的方式展示提交历史。 这个选项有一些内建的子选项供你使用。 比如 oneline 会将每个提交放在一行显示,在浏览大量的提交时非常有用。 另外还有 shortfullfuller 选项,它们展示信息的格式基本一致,但是详尽程度不一:
Git(7)-- 查看提交历史(git log 命令详解)

6、git log --pretty=short

Git(7)-- 查看提交历史(git log 命令详解)

7、git log --pretty=full

Git(7)-- 查看提交历史(git log 命令详解)

8、git log --pretty=fuller

Git(7)-- 查看提交历史(git log 命令详解)

9、定制记录的显示格式:git log --pretty=format

最有意思的是 format ,可以定制记录的显示格式。 这样的输出对后期提取分析格外有用——因为你知道输出的格式不会随着 Git 的更新而发生改变:

Git(7)-- 查看提交历史(git log 命令详解)
git log --pretty=format 常用的选项 列出了 format 接受的常用格式占位符的写法及其代表的意义。

git log --pretty=format 常用的选项

选项 说明
%H 提交的完整哈希值
%h 提交的简写哈希值
%T 树的完整哈希值
%t 树的简写哈希值
%P 父提交的完整哈希值
%p 父提交的简写哈希值
%an 作者名字
%ae 作者的电子邮件地址
%ad 作者修订日期(可以用 --date=选项 来定制格式)
%ar 作者修订日期,按多久以前的方式显示
%cn 提交者的名字
%ce 提交者的电子邮件地址
%cd 提交日期
%cr 提交日期(距今多长时间)
%s 提交说明

作者指的是实际作出修改的人,提交者指的是最后将此工作成果提交到仓库的人。 所以,当你为某个项目发布补丁,然后某个核心成员将你的补丁并入项目时,你就是作者,而那个核心成员就是提交者。

onelineformat 与另一个 log 选项 --graph 结合使用时尤其有用。 这个选项添加了一些 ASCII 字符串来形象地展示你的分支、合并历史:

Git(7)-- 查看提交历史(git log 命令详解)

在git源码库中使用此命令,项目太多了,截图两张了解下:
首页:
Git(7)-- 查看提交历史(git log 命令详解)
某一页:
Git(7)-- 查看提交历史(git log 命令详解)
以上只是简单介绍了一些 git log 命令支持的选项。 git log 的常用选项 列出了我们目前涉及到的和没涉及到的选项,以及它们是如何影响 log 命令的输出的。

git log 的常用选项

选项 说明
-p 按补丁格式显示每个提交引入的差异。
--stat 显示每次提交的文件修改统计信息。
--shortstat 只显示 --stat 中最后的行数修改添加移除统计。
--name-only 仅在提交信息后显示已修改的文件清单。
--name-status 显示新增、修改、删除的文件清单。
--abbrev-commit 仅显示 SHA-1 校验和所有 40 个字符中的前几个字符。
--relative-date 使用较短的相对时间而不是完整格式显示日期(比如“2 weeks ago”)。
--graph 在日志旁以 ASCII 图形显示分支与合并历史。
--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline、short、full、fuller 和 format(用来定义自己的格式)。
--oneline --pretty=oneline --abbrev-commit 合用的简写。

10、git log --oneline

Git(7)-- 查看提交历史(git log 命令详解)
Git(7)-- 查看提交历史(git log 命令详解)

11、限制输出长度

除了定制输出格式的选项之外,git log 还有许多非常实用的限制输出长度的选项,也就是只输出一部分的提交。 之前你已经看到过 -2 选项了,它只会显示最近的两条提交, 实际上,你可以使用类似 -<n> 的选项,其中的 n 可以是任何整数,表示仅显示最近的 n 条提交。 不过实践中这个选项不是很常用,因为 Git 默认会将所有的输出传送到分页程序中,所以你一次只会看到一页的内容。

但是,类似 --since--until 这种按照时间作限制的选项很有用。 例如,下面的命令会列出最近两周的所有提交:git log --since=2.weeks

最近14年的所有提交:

git log --since=14.years

Git(7)-- 查看提交历史(git log 命令详解)
该命令可用的格式十分丰富——可以是类似 "2008-01-15" 的具体的某一天,也可以是类似 "14 years 1 day 3 minutes ago" 的相对日期。

git log --since=14 years 1 day 3 minutes ago

Git(7)-- 查看提交历史(git log 命令详解)

git log --since="2008-01-15"

Git(7)-- 查看提交历史(git log 命令详解)
还可以过滤出匹配指定条件的提交。 用 --author 选项显示指定作者的提交,用 --grep 选项搜索提交说明中的关键字。

你可以指定多个 --author 和 --grep 搜索条件,这样会只输出 任意 匹配 --author 模式和 --grep 模式的提交。然而,如果你添加了 --all-match 选项, 则只会输出 所有 匹配 --grep 模式的提交。

另一个非常有用的过滤器是 -S, 它接受一个字符串参数,并且只会显示那些添加或删除了该字符串的提交。 假设你想找出添加或删除了对某一个特定函数的引用的提交,可以调用:

git log -S function_name

最后一个很实用的 git log 选项是路径(path), 如果只关心某些文件或者目录的历史提交,可以在 git log 选项的最后指定它们的路径。 因为是放在最后位置上的选项,所以用两个短划线(--)隔开之前的选项和后面限定的路径名。

限制 git log 输出的选项 中列出了常用的选项。

限制 git log 输出的选项

选项 说明
-<n> 仅显示最近的 n 条提交。
--since, --after 仅显示指定时间之后的提交。
--until, --before 仅显示指定时间之前的提交。
--author 仅显示作者匹配指定字符串的提交。
--committer 仅显示提交者匹配指定字符串的提交。
--grep 仅显示提交说明中包含指定字符串的提交。
-S 仅显示添加或删除内容匹配指定字符串的提交。

12、实例:

来看一个实际的例子,如果要在 Git 源码库中查看 Junio Hamano 在 2008 年 10 月其间, 除了合并提交之外的哪一个提交修改了测试文件,可以使用下面的命令:
git log --pretty="%h - %s" --author=‘Junio C Hamano‘ --since="2008-10-01" --before="2008-11-01" --no-merges -- t/

Git 源码库:https://github.com/git/git
Git(7)-- 查看提交历史(git log 命令详解)

clone: git clone https://github.com/git/git.git
Git(7)-- 查看提交历史(git log 命令详解)
命令:

git log --pretty="%h - %s" --author=‘Junio C Hamano‘ --since="2008-10-01" --before="2008-11-01" --no-merges -- t/

Git(7)-- 查看提交历史(git log 命令详解)
在近 40000 条提交中,上面的输出仅列出了符合条件的 6 条记录。

隐藏合并提交: 按照你代码仓库的工作流程,记录中可能有为数不少的合并提交,它们所包含的信息通常并不多。为了避免显示的合并提交弄乱历史记录,可以为 log 加上 --no-merges 选项。

Git(7)-- 查看提交历史(git log 命令详解)

Git(7)-- 查看提交历史(git log 命令详解)

上一篇:pom打增量包,使用mvn命令对pom.xml打增量包


下一篇:poi 4.11版本 word模板操作