• Git 查看提交历史


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

    git log - 查看历史提交记录。

    git blame - 以列表形式查看指定文件的历史修改记录。

    git log

    git log - 查看历史提交记录。

    git log

    在使用 Git 提交了若干更新之后,又或者克隆了某个项目,想回顾下提交历史,我们可以使用 git log 命令查看。

    git log 命令用于查看 Git 仓库中提交历史记录。

    git log 显示了从最新提交到最早提交的所有提交信息,包括提交的哈希值、作者、提交日期和提交消息等。

    git log 命令的基本语法:

    git log [选项] [分支名/提交哈希]

    常用的选项包括:

    -p:显示提交的补丁(具体更改内容)。

    --oneline:以简洁的一行格式显示提交信息。

    --graph:以图形化方式显示分支和合并历史。

    --decorate:显示分支和标签指向的提交。

    --author=<作者>:只显示特定作者的提交。

    --since=<时间>:只显示指定时间之后的提交。

    --until=<时间>:只显示指定时间之前的提交。

    --grep=<模式>:只显示包含指定模式的提交消息。

    --no-merges:不显示合并提交。

    --stat:显示简略统计信息,包括修改的文件和行数。

    --abbrev-commit:使用短提交哈希值。

    --pretty=<格式>:使用自定义的提交信息显示格式。

    针对我们前一章节的操作,使用 git log 命令列出历史提交记录如下:

    1. $ git log
    2. commit d5e9fc2c811e0ca2b2d28506ef7dc14171a207d9 (HEAD -> master)
    3. Merge: c68142b 7774248
    4. Author: runoob <test@runoob.com>
    5. Date: Fri May 3 15:55:58 2019 +0800
    6. Merge branch 'change_site'
    7. commit c68142b562c260c3071754623b08e2657b4c6d5b
    8. Author: runoob <test@runoob.com>
    9. Date: Fri May 3 15:52:12 2019 +0800
    10. 修改代码
    11. commit 777424832e714cf65d3be79b50a4717aea51ab69 (change_site)
    12. Author: runoob <test@runoob.com>
    13. Date: Fri May 3 15:49:26 2019 +0800
    14. changed the runoob.php
    15. commit c1501a244676ff55e7cccac1ecac0e18cbf6cb00
    16. Author: runoob <test@runoob.com>
    17. Date: Fri May 3 15:35:32 2019 +0800

    我们可以用 --oneline 选项来查看历史记录的简洁的版本

    1. $ git log --oneline
    2. d5e9fc2 (HEAD -> master) Merge branch 'change_site'
    3. c68142b 修改代码
    4. 7774248 (change_site) changed the runoob.php
    5. c1501a2 removed test.txt、add runoob.php
    6. 3e92c19 add test.txt
    7. 3b58100 第一次版本提交

    这告诉我们的是,此项目的开发历史。

    我们还可以用 --graph 选项,查看历史中什么时候出现了分支、合并。以下为相同的命令,开启了拓扑图选项:

    1. * d5e9fc2 (HEAD -> master) Merge branch 'change_site'
    2. |\
    3. | * 7774248 (change_site) changed the runoob.php
    4. * | c68142b 修改代码
    5. |/
    6. * c1501a2 removed test.txt、add runoob.php
    7. * 3e92c19 add test.txt
    8. * 3b58100 第一次版本提交

    现在我们可以更清楚明了地看到何时工作分叉、又何时归并。

    你也可以用 --reverse 参数来逆向显示所有日志。

    1. $ git log --reverse --oneline
    2. 3b58100 第一次版本提交
    3. 3e92c19 add test.txt
    4. c1501a2 removed test.txt、add runoob.php
    5. 7774248 (change_site) changed the runoob.php
    6. c68142b 修改代码
    7. d5e9fc2 (HEAD -> master) Merge branch 'change_site'

    如果只想查找指定用户的提交日志可以使用命令:git log --author , 例如,比方说我们要找 Git 源码中 Linus 提交的部分:

    1. $ git log --author=Linus --oneline -5
    2. 81b50f3 Move 'builtin-*' into a 'builtin/' subdirectory
    3. 3bb7256 make "index-pack" a built-in
    4. 377d027 make "git pack-redundant" a built-in
    5. b532581 make "git unpack-file" a built-in
    6. 112dd51 make "mktag" a built-in

    如果你要指定日期,可以执行几个选项:--since 和 --before,但是你也可以用 --until 和 --after。

    例如,如果我要看 Git 项目中三周前且在四月十八日之后的所有提交,我可以执行这个(我还用了 --no-merges 选项以隐藏合并提交):

    1. $ git log --oneline --before={3.weeks.ago} --after={2010-04-18} --no-merges
    2. 5469e2d Git 1.7.1-rc2
    3. d43427d Documentation/remote-helpers: Fix typos and improve language
    4. 272a36b Fixup: Second argument may be any arbitrary string
    5. b6c8d2d Documentation/remote-helpers: Add invocation section
    6. 5ce4f4e Documentation/urls: Rewrite to accomodate transport::address
    7. 00b84e9 Documentation/remote-helpers: Rewrite description
    8. 03aa87e Documentation: Describe other situations where -z affects git diff
    9. 77bc694 rebase-interactive: silence warning when no commits rewritten
    10. 636db2c t3301: add tests to use --format="%N"

    更多 git log 命令可查看 Git - git-log Documentation 或使用 git log --help 命令查看帮助信息。

    git blame

    以列表形式查看指定文件的历史修改记录

    git blame 命令用于逐行显示指定文件的每一行代码是由谁在什么时候引入或修改的。

    strong>git blame 可以追踪文件中每一行的变更历史,包括作者、提交哈希、提交日期和提交消息等信息。

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

    git blame [选项] <文件路径>

    常用的选项包括:

    -L <起始行号>,<结束行号>:只显示指定行号范围内的代码注释。

    -C:对于重命名或拷贝的代码行,也进行代码行溯源。

    -M:对于移动的代码行,也进行代码行溯源。

    -C -C-M -M:对于较多改动的代码行,进行更进一步的溯源。

    --show-stats:显示包含每个作者的行数统计信息。

    显示文件每一行的代码注释和相关信息:

    git blame <文件路径>

    只显示指定行号范围内的代码注释:

    git blame -L <起始行号>,<结束行号> <文件路径>

    对于重命名或拷贝的代码行进行溯源:

    git blame -C <文件路径>

    对于移动的代码行进行溯源:

    git blame -M <文件路径>

    显示行数统计信息:

    git blame --show-stats <文件路径>

    git blame 命令是以列表形式显示修改记录,如下实例:

    1. $ git blame README
    2. ^d2097aa (tianqixin 2020-08-25 14:59:25 +0800 1) # Runoob Git 测试
    3. db9315b0 (runoob 2020-08-25 16:00:23 +0800 2) # 新手教程

  • 相关阅读:
    暑假算法训练day3
    jQuery常用插件整理(持续更新)
    【Kotlin精简】第1章 基础类型
    Linux学习之Redis使用
    pikachu靶场搭建及通关
    9成企业打算发年终奖,人均到手2.3万元
    [SQL开发笔记]在windows系统安装Postgres
    一句话总结Docker与K8S的关系
    Vue 3 中如何迁移从 Vue 2 的项目?
    <Linux>(极简关键、省时省力)《Linux操作系统原理分析之Linux 进程管理 4》(8)
  • 原文地址:https://blog.csdn.net/h4241778/article/details/134467558