软件开发入门教程网之Git 查看提交历史
2023-06-13 09:16:40 时间
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 log 命令可查看:http://git-scm.com/docs/git-log
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的cherry-pick 这个命令你会经常用到!
- 彻底解决git clone以及 recursive慢的问题
- (数据科学学习手札141)利用Learn Git Branching轻松学习git常用操作
- git查看,修改用户名和邮箱「建议收藏」
- Git分布式版本控制工具学习(一)
- Git结构+代码托管中心_本地库和远程库的交互方式
- git拉取代码如何解决冲突_Git工具-git pull拉取代码时冲突的解决办法[通俗易懂]
- git worktree
- git 本地文件上传 github || gitee
- Windows 下 Git 拉 Gitlab 代码
- Git版本控制入门教程(一)
- Centos搭建GIT服务器
- 软件开发入门教程网之Git 基本操作
- 软件开发入门教程网之Git 分支管理
- Git忽略已经提交过一次文件Git忽略文件
- 分享5个Git使用技巧
- 【Git】Git 分支管理 ( 创建并切换分支 | 查看分支 git branch | 合并分支 git merge dev | 删除分支 git branch -d dev )
- 【Git】Git 分支管理 ( 使用 git cherry-pick 命令提取提交记录应用于当前分支 | 创建新分支应用某个提交 | git cherry-pick 冲突处理 )
- Python 进阶指南(编程轻松进阶):十二、使用 Git 组织您的代码项目
- Git在windows下上传文件至github流程详解程序员
- Linux快速配置Git环境(linux配置git)
- 下使用git在Linux下使用Git:简单易学.(如何在linux)
- 使用Git在Linux系统中管理代码(linux中的git命令)
- 快速启动Linux下的Git服务(linux启动git服务)
- 极速学习:Linux下使用Git的基础知识(linux如何使用git)
- 深入浅出:Linux下Git使用指南(linux下git使用)
- 如何在Linux上配置Git:简易指南(linux下git配置)
- 让Oracle支持Git(oracle中的git)
- 从Git合集进入Redis集群的新路(redis集群git合集)
- 开创自动化Redis集群Git部署(redis集群git)