开心档之Git查看提交历史

简介: 开心档之Git查看提交历史

Git 查看提交历史

Git 提交历史一般常用两个命令:

  • git log - 查看历史提交记录。
  • git blame <file> - 以列表形式查看指定文件的历史修改记录。


git log {#git-log}

  • 在使用 Git 提交了若干更新之后,又或者克隆了某个项目,想回顾下提交历史,我们可以使用 git log 命令查看。
  • 针对我们前一章节的操作,使用 git log 命令列出历史提交记录如下:
$ git log
commit d5e9fc2c811e0ca2b2d28506ef7dc14171a207d9 (HEAD -> master)
Merge: c68142b 7774248
Author: kxdang <test@kxdang.com>
Date:   Fri May 3 15:55:58 2019 +0800
    Merge branch 'change_site'
commit c68142b562c260c3071754623b08e2657b4c6d5b
Author: kxdang <test@kxdang.com>
Date:   Fri May 3 15:52:12 2019 +0800
    修改代码
commit 777424832e714cf65d3be79b50a4717aea51ab69 (change_site)
Author: kxdang <test@kxdang.com>
Date:   Fri May 3 15:49:26 2019 +0800
    changed the kxdang.php
commit c1501a244676ff55e7cccac1ecac0e18cbf6cb00
Author: kxdang <test@kxdang.com>
Date:   Fri May 3 15:35:32 2019 +0800
  • 我们可以用 --oneline 选项来查看历史记录的简洁的版本。
$ git log --oneline
$ git log --oneline
d5e9fc2 (HEAD -> master) Merge branch 'change_site'
c68142b 修改代码
7774248 (change_site) changed the kxdang.php
c1501a2 removed test.txt、add kxdang.php
3e92c19 add test.txt
3b58100 第一次版本提交
  • 这告诉我们的是,此项目的开发历史。
  • 我们还可以用 --graph 选项,查看历史中什么时候出现了分支、合并。以下为相同的命令,开启了拓扑图选项:
*   d5e9fc2 (HEAD -> master) Merge branch 'change_site'
|\  
| * 7774248 (change_site) changed the kxdang.php
* | c68142b 修改代码
|/  
* c1501a2 removed test.txt、add kxdang.php
* 3e92c19 add test.txt
* 3b58100 第一次版本提交
  • 现在我们可以更清楚明了地看到何时工作分叉、又何时归并。
  • 你也可以用 --reverse 参数来逆向显示所有日志。
$ git log --reverse --oneline
3b58100 第一次版本提交
3e92c19 add test.txt
c1501a2 removed test.txt、add kxdang.php
7774248 (change_site) changed the kxdang.php
c68142b 修改代码
d5e9fc2 (HEAD -> master) Merge branch 'change_site'
  • 如果只想查找指定用户的提交日志可以使用命令:git log --author , 例如,比方说我们要找 Git 源码中 Linus 提交的部分:
$ git log --author=Linus --oneline -5
81b50f3 Move 'builtin-*' into a 'builtin/' subdirectory
3bb7256 make "index-pack" a built-in
377d027 make "git pack-redundant" a built-in
b532581 make "git unpack-file" a built-in
112dd51 make "mktag" a built-in
  • 如果你要指定日期,可以执行几个选项:--since 和 --before,但是你也可以用 --until 和 --after。
  • 例如,如果我要看 Git 项目中三周前且在四月十八日之后的所有提交,我可以执行这个(我还用了 --no-merges 选项以隐藏合并提交):
$ git log --oneline --before={3.weeks.ago} --after={2010-04-18} --no-merges
5469e2d Git 1.7.1-rc2
d43427d Documentation/remote-helpers: Fix typos and improve language
272a36b Fixup: Second argument may be any arbitrary string
b6c8d2d Documentation/remote-helpers: Add invocation section
5ce4f4e Documentation/urls: Rewrite to accomodate transport::address
00b84e9 Documentation/remote-helpers: Rewrite description
03aa87e Documentation: Describe other situations where -z affects git diff
77bc694 rebase-interactive: silence warning when no commits rewritten
636db2c t3301: add tests to use --format="%N"

git blame {#git-blame}

如果要查看指定文件的修改记录可以使用 git blame 命令,格式如下:

git blame <file>
  • git blame 命令是以列表形式显示修改记录,如下实例:
$ git blame README 
^d2097aa (tianqixin 2020-08-25 14:59:25 +0800 1) # Runoob Git 测试
db9315b0 (kxdang    2020-08-25 16:00:23 +0800 2) # 菜鸟教程 


目录
相关文章
|
缓存 开发工具 git
开心档之Git基本操作
开心档之Git基本操作
40 0
|
开发工具 git
开心档之Git分支管理
开心档之Git分支管理
51 0
|
Linux Shell 开发工具
开心档之Git创建仓库
开心档之Git创建仓库
39 0
|
网络安全 项目管理 开发工具
开心档之Git Gitee
开心档之Git Gitee
29 0
|
3月前
|
存储 开发工具 git
|
3月前
|
开发工具 git
【GIT 第二篇章】GIT常用命令
Git常用命令涵盖初始化、状态管理、提交、分支处理、远程操作等关键流程。`git init`启动本地仓库,`git clone`下载远程仓库。通过`git status`和`git diff`检查工作状态与差异。利用`git add`暂存文件,`git commit`保存更改。借助`git branch`、`git checkout`、`git merge`和`git rebase`管理分支。使用`git fetch`、`git pull`和`git push`同步远程仓库。通过`git reset`、`git revert`和`git checkout`实现版本回退。
63 0
|
20天前
|
开发工具 git
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
这篇文章是关于Git常用命令的总结,包括初始化配置、基本提交、分支操作、合并、压缩历史、推送和拉取远程仓库等操作的详细说明。
68 1
git学习四:常用命令总结,包括创建基本命令,分支操作,合并命令,压缩命令,回溯历史命令,拉取命令
|
19小时前
|
开发工具 git 开发者
|
19小时前
|
开发工具 git 开发者
提升Git效率:掌握这5个高级命令
【10月更文挑战第17天】
7 0
|
2月前
|
存储 Linux 开发工具
掌握 Git 命令:每个开发者的必备技能
无论团队项目还是个人开发,掌握 Git 命令都是必备技能。本文介绍 Git 的基本概念与命令,如初始化仓库 (`git init`)、添加文件 (`git add`)、提交更改 (`git commit`)、检出分支 (`git checkout`)、合并分支 (`git merge`) 等,还分享了高级技巧如查看差异 (`git diff`)、撤销提交 (`git revert`)、修复合并冲突 (`git mergetool`) 和使用别名简化命令 (`git config --global alias.ci commit`)。