超级详细Git操作 之git log 命令的参数详解

news2025/1/11 22:41:06

git log命令主要用于查看Git版本演变历史(也就是提交历史),同时根据追加的参数和选项不同,也会有不同的展示效果。

但默认git log命令显示出的x效果实在太丑,不好好打扮一下根本没法见人,打扮好了用alias命令拍个照片,就正式出道了!

1、git log命令说明

git log用于查询版本的历史,命令形式如下:

git log [<options>] [<since>..<until>] [[--] <path>...]

默认的git log命令显示效果如下:

(之前文件详细说明过了,这里简单说一下,主要说明git log命令的参数)

2、git log命令参数

这条命令有很多参数选项,下面详细的说明:

(1)不带参数

  1. 如果不带任何参数,它会列出所有历史记录,最近的排在最上方,显示提交对象的哈希值,作者、提交日期、和提交说明
  2. 如果记录过多,则按上下键Enter(向下显示一行),空格(显示下一页),来控制显示。
  3. q键退出历史记录列表。

(2)常用显示参数

  1. -p:按补丁格式显示每个更新的差异,比下一条--stat命令信息更全。
  2. --stat:显示每次提交修改文件的统计信息,每个提交都列出了修改过的文件,以及其中添加和移除的行数,并在最后列出所有增减行数小计。
  3. --shortstat:只显示--stat中最后的行数添加、修改、删除的统计。
  4. --name-only:仅在提交信息后,显示已修改的文件清单。
  5. --name-status:显示新增、修改、删除的文件清单。
  6. --abbrev-commit:仅显示SHA-1校验和的前几个字符,而非所有的40个字符。
  7. --relative-date:使用较短的相对时间,而不是完整格式显示日期(比如“2 weeks ago”)。
  8. --graph:在日志旁以 ASCII 图形显示分支与合并历史。
  9. --online:列表的形式查看历史版本记录,--pretty=oneline --abbrev-commit 合用的简写。
  10. --pretty:使用其他格式显示历史提交信息。可用的选项包括onelineshortfullfullerformat(用来定义自己的格式)。

(3)--pretty参数

--pretty:自定义格式化显示历史提交信息。

选项有:

1)--pretty=oneline:一行显示,只显示哈希值和提交说明(--online本身也可以作为单独的属性)。

2)--pretty=format:” ":控制显示信息的格式。

序号格式说明
1%H提交的完整哈希值(commit-id)。
2%h提交的简写哈希值。
3%T树的完整哈希值(tree)。
4%t树的简写哈希值。
5%P父提交(parent)的完整哈希值。
6%p父提交的简写哈希值。
7%an作者名字(author)。
8%ae作者的电子邮件地址。
9%ad作者修订日期(可以用 --date=选项 来定制格式)。
10%ar作者修订日期,按多久以前的方式显示。
11%cn提交者的名字(committer)。
12%ce提交者的电子邮件地址。
13%cd提交日期(可以用 --date=选项 来定制格式)。
14%cr提交日期,按多久以前的方式显示。
15%s提交说明。

3)--pretty=format:” ":控制显示信息的颜色。

  1. 颜色格式:

    %Cred:将颜色切换为红色

    %Cgreen:将颜色切换为绿色

    %Cblue:将颜色切换为蓝色

    %Creset:空格

  2. 举例:

    执行命令:git log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %C(cyan)%s %C(magenta)(%cr) %C(bold blue)<%an>%Creset'
    两种效果如下:

  3. 我们先进行断句分析:[%Cred%h][%Creset -][%C(yellow)%d ][%Cblue%s][%Cgreen(%cd)][%C(bold blue)<%an>]
    然后就是很明显能得到的规律了:

    • 写法:一个颜色+一个内容,例如%Cred%h,依次排写。
    • 颜色以%C开头,后边接几种颜色,还可以设置字体,如果要设置字体的话,要一块加个括号。
      能设置的颜色值包括:reset(默认的灰色),normalblackredgreenyellowbluemagentacyanwhite。(不能单独使用就加括号)
      字体属性则有bolddimulblinkreverse
    • 内容可以是占位元字符,也可以是直接显示的普通字符(例如上面的-

(4)--date=参数

--date=(relative|local|default|iso|rfc|short|raw)

仅对以人类可读格式显示的日期生效,例如使用--pretty.log.date这个config变量设置日志的默认值。

--date有几个默认选项:

  1. --date=relative:显示相对于当前时间的日期,例如"2小时前"。
  2. --date=local:显示用户本地时区中的时间戳。
  3. --date=iso--date=iso8601:以ISO 8601格式显示时间戳。
  4. --date=rfc--date=rfc2822:以RFC 2822格式显示时间戳,通常在电子邮件中找到。
  5. --date=short:仅以YYYY-MM-DD格式显示日期,而不显示时间。
  6. --date=raw:以内部原始Git格式%s %z格式显示日期。
  7. --date=default:显示原始时区(提交者或作者)的时间戳。

也可以自定义格式(需要git版本2.6.0以上)

比如:--date=format:'%Y-%m-%d %H:%M:%S',会格式化成:2016-01-13 11:32:13

其他的格式化占位符如下:

  1. %a:星期的缩写。
  2. %A:星期的全名。
  3. %b:月份的缩写。
  4. %B:月份的全称。
  5. %c:适用于区域设置的日期和时间表示。
  6. %d:月中的天作为十进制数字(01 – 31)。
  7. %H: 24小时制的小时(00 – 23)。
  8. %I:2小时格式的小时(01 – 12)。
  9. %j:一年中的天作为十进制数字(001 – 366)。
  10. %m:以十进制数字表示的月份(01 – 12)。
  11. %M:分钟以十进制数字表示(00 – 59)。
  12. %p:当前语言环境的"上午/下午",12小时制的指示器。
  13. %S:秒作为十进制数字(00 – 59)。
  14. %U:一年中的周为十进制数字,周日为一周的第一天(00 – 53)。
  15. %w:工作日为十进制数字(0 – 6;星期日为0)。
  16. %W:一年中的星期作为十进制数字,星期一作为星期的第一天(00 – 53)
  17. %x:当前语言环境的日期表示。
  18. %X:当前语言环境的时间表示。
  19. %y:无世纪的年份,为十进制数字(00 – 99),也就是年份没有前两位。
  20. %Y:带世纪的年份,以十进制数表示。
  21. %z%Z:时区名称或时区缩写,取决于注册表设置; 如果时区未知,则没有字符。
  22. %%:表示百分号。

(5)筛选参数

1)按数量

  • -n:显示前n条提交信息。

2)按日期

  1. --after=
    1. 比如git log --after="2014-7-1”,显示2014年7月1号之后的commit(包含7月1号)。
    2. 后边的日期还可以用相对时间表示,比如"1 week ago"”yesterday",比如git log --after="yesterday"
  2. --before=:同上。

另外这两条命令可以同时使用表示时间段,比如git log --after="2014-7-1" --before="2014-7-4"

同理:--since--until--after--before是一个意思。

--since, --after:仅显示指定时间之后的提交。

--until, --before:仅显示指定时间之前的提交。

3)按作者和提交者

--author=:仅显示作者匹配指定字符串的提交。

  1. 比如git log --author=“John",显示John贡献的commit。
  2. 注意:作者名不需要精确匹配,只需要包含就行了。
  3. 而且可以使用正则表达式,比如git log --author="John|Mary”,搜索Marry和John贡献的commit。
  4. 而且这个--author不仅包含作者名,还包含作者的email,所以你可以用这个搜索email。

--committer:仅显示提交者匹配指定字符串的提交。

4)按commit描述

--grep=:仅显示提交说明中包含指定字符串的提交。

  1. 比如:git log --grep="JRA-224"
  2. 而且可以传入-i用来忽略大小写。
  3. 注意:如果想同时使用--grep--author,必须在附加一个--all-match参数。

5)按文件

--(空格)文件--[后边没有文件]

  1. 有时你可能只对某个文件的修改感兴趣,或你只想查看跟某个文件相关的历史信息,你只需要插入你感兴趣文件的路径,[对,是路径,所以经常是不太好用]就可以了。
  2. 比如:git log -- foo.py bar.py ,只返回和foo.py文件或bar.py文件的相关commit。
  3. 这里的--是告诉Git,后面的参数是文件路径而不是branch(分支)的名字。 如果后面的文件路径不会和某个branch产生混淆,你可以省略--,比如git log foo.py
  4. 另外,后边的路径还支持正则,比如:git log *install.md ,是指定项目路径下的所有以install.md结尾文件的提交历史。
  5. 另外,文件名应该放到参数的最后位置,通常在前面加上--并用空格隔开表示是文件。
  6. 另外,git log file/,可以查看file文件夹下所有文件的提交记录。

6)按分支

--

  1. --branchName branchName参数:为任意一个分支名字,查看某个分支上的提交记录。

  2. 需要放到参数中的最后位置处。

  3. 如果分支名与文件名相同,系统会提示错误,可通过--选项,来指定给定的参数,是分支名还是文件名。

    比如:在当前分支中有一个名为v1的文件,同时还存在一个名为v1的分支。如下:

    git log v1 --,此时的v1代表的是分支名字(--后边是空的)。

    git log -- v1,此时的v1代表的是名为v1的文件。

    git log v1 -- v1:代表v1分支下的v1文件。

7)按内容

-S"<string>"-G"<string>":仅显示添加或删除内容匹配指定字符串的提交。

  1. 有时你想搜索,新增或删除某行代码相关的commit. 可以使用这条命令。
  2. 假设你想知道Hello,World!这句话,是什么时候加入到项目里去的,可以用:git log -S"Hello,World!"
  3. 另外,如果你想使用正则表达式去匹配,而不是字符串,那么你可以使用-G代替-S
  4. 这是一个非常有用的debug工具,使用他可以定位所有跟某行代码相关的commit,甚至可以查看某行是什么时候被copy的,什么时候移到另外一个文件中去的。
  5. 注意:-S后没有"=",与查询内容之间也没有空格符。

8)按范围

git log <since>..<until>

  1. 这个命令可以查看某个范围的commit。
  2. 这个命令非常有用当你使用branch做为range参数的时候. 能很方便的显示2个branch(分支)之间的不同。
  3. 比如:git log master..featuremaster..feature这个range(范围),包含了在feature分支存在,而在master分支没有的所有commit。同样,如果是feature..master,意思是包含所有master分支有,但是feature分支没有的commit。
  4. 另外,如果是三个点,表示或的意思:git log master...test,意思是查询mastertest分支中的提交记录。

9)过滤掉merge commit

--no-merges

  1. 默认情况下git log会输出merge commit(合并提交)。你可以通过--no-merges标记来过滤掉merge commit,例如:git log --no-merges
  2. 另外,如果你只对merge commit感兴趣可以使用--merges参数,例如:git log --merges

10)按标签tag

git log v1.0

  1. 直接这样是查询标签之前的commit。
  2. 加两个点,例如:git log v1.0..,是查询从v1.0以后的提交历史记录(不包含v1.0)。

11)按commit

  1. git log commit:查询commit之前的记录,包含commit。
  2. git log commit1 commit2:查询commit1与commit2之间的记录,包括commit1和commit2。
  3. git log commit1..commit2:同上,但是不包括commit1。

说明:

  • 其中,commit可以是提交哈希值的简写模式,也可以使用HEAD代替。
  • HEAD代表最后一次提交,HEAD^为最后一个提交的父提交,等同于HEAD~1
  • HEAD~2代表倒数第二次提交。

提示:Git的指令是非常丰富的,通过git help log 或者git help --web log,可以以浏览器的方式查看更多关于log的指令。

实战案例

光学理论是没用的,要学会跟着一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

如果对你有帮助的话,点个赞收个藏,给作者一个鼓励。也方便你下次能够快速查找。

如有不懂还要咨询下方小卡片,博主也希望和志同道合的测试人员一起学习进步

在适当的年龄,选择适当的岗位,尽量去发挥好自己的优势。

我的自动化测试开发之路,一路走来都离不每个阶段的计划,因为自己喜欢规划和总结,

测试开发视频教程、学习笔记领取传送门!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/538164.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

chatgpt赋能Python-pycharm怎么重新配置python环境

Pycharm重新配置Python环境方法概述 如果您是Python编程的专业人士或者是刚开始学习Python&#xff0c;您可能已经听说了Pycharm这个IDE。Pycharm不仅可以提高您Python编程的效率&#xff0c;而且也大大改善了整个开发过程。不过&#xff0c;如果您需要使用Pycharm重新配置Pyt…

深度学习用于医学预后-第二课第四周1-4节随堂作业

作业名&#xff1a;C2_W4_lecture.ipynb 作业地址&#xff1a; github --> bharathikannann/AI-for-Medicine-Specialization-deeplearning.ai --> AI for Medical Prognosis --> Week 4 One-hot encode categorical variables 首先我们来看一下哪些特征是分类特征…

Maven高级篇

分模块开发与设计 ssm_pojo拆分 新建模块拷贝原始项目中对应的相关内容到ssm_pojo模块中 实体类&#xff08;User&#xff09;配置文件&#xff08;无&#xff09; ssm_dao拆分 新建模块拷贝原始项目中对应的相关内容到ssm_dao模块中 数据层接口&#xff08;UserDao&#x…

spring学习笔记(2)

目录 RESTful Web 服务是干啥用的&#xff1f; 这个是什么意思&#xff1f;“OpenJDK 64-Bit Server VM warning: Options -Xverify:none and -noverify were deprecated in JDK 13 and will likely be removed in a future release.” 构建一个RESTful Web服务 GB有多大 点击…

IBM 创新方案+SNP数据转型助一汽大众实现数据平稳、高效迁移

近日&#xff0c;IBM 采用基于SNP Bluefield技术迁移的IBM Rapid Move创新数据迁移方案, 成功为一汽-大众实施了企业运营数据系统从 ECC 到 S/4 的升级项目。该项目系统切换耗时仅三天&#xff0c;不仅助客户高效、平稳迁移了系统数据&#xff0c;升级了数据底座&#xff0c;还…

第六讲:“声音”写具体

爸爸又打呼了!“呼噜一呼噜一像一股巨浪腾空而起&#xff0c;以每秒八十米的速度向上冲刺&#xff0c;力图掀开天花板&#xff0c;掀翻整座住宅楼;“呼噜一一呼噜一-”&#xff0c;像一台轰鸣的坦克在穿行&#xff0c;床垫在抖动&#xff0c;吊灯在摇晃&#xff0c;墙灰在簌籁(…

【办公软件篇】Listary搜索神器清除搜索历史记录

【办公软件篇】Listary搜索神器清除搜索历史记录 装机必备搜索神器—【蘇小沐】 文章目录 【办公软件篇】Listary搜索神器清除搜索历史记录1.实验环境 &#xff08;一&#xff09;删除搜索历史记录总结 1.实验环境 官网地址&#xff1a;Listary Discussions 系统版本Windows…

chatgpt赋能Python-pycharm怎么添加库函数

PyCharm怎么添加库函数 作为一位拥有10年python编程经验的工程师&#xff0c;我可以告诉大家&#xff0c;PyCharm是一个非常优秀的Python集成开发环境&#xff0c;它可以帮助我们更加高效地编写Python代码。但是在使用PyCharm的时候&#xff0c;我们经常需要使用一些库函数&am…

Vue3——简易个人空间(下半部分)

书接上回: 好友列表页面实现: 根据提供的api从云端将10个用户读进来 根据提供的api获得如下的json格式的数据&#xff0c;里面有四个用户的信息。 这里使用ajax进行实现要先在项目中安装jquery&#xff0c;使用命令行安装 npm i jquery然后在用户列表页面要先引入jquery i…

数据结构——插入排序与希尔排序

&#x1f307;个人主页&#xff1a;_麦麦_ &#x1f4da;今日名言&#xff1a;喜你成疾&#xff0c;药石无医。——《玫瑰与鹿》 一、前言 在本篇文章&#xff0c;我们将为小伙伴们进行排序概念的基本讲解并具体讲解其中的两种基础排序&#xff1a;插入排序和希尔排序&#xff…

BSQ格式数据转换为RSD缺省的BIP格式数据

李国春 RSD内部统一以BIP格式排列数据&#xff0c;并且文件格式&#xff08;非TFS&#xff09;数据倒放&#xff08;North Down&#xff09;。早期是为了和设备无关位图&#xff08;DIB&#xff09;一致节省一点处理时间。现在设备处理能力增强了这点时间已经无关紧要&#xf…

目标检测复盘 -- 1.mAP及其他评价指标

前言 为什么想单独做一个目标检测篇&#xff0c;主要是感觉自己是个半吊子&#xff0c;满瓶不响、半瓶晃荡&#xff0c;找工作的过程中&#xff0c;也被很多面试官问到哑口无言&#xff0c;基础真的不扎实&#xff0c;自己非常虚&#xff0c;想好好地、静下心来捋一下&#xf…

Linux环境搭建及问题解决方案

本文介绍了Linux环境搭建的过程以及遇到的问题和解决方案&#xff0c;并且介绍了常用的Linux命令. 一、Linux环境搭建 整体所需的环节 安装VMware安装Linux &#xff08;这边我选的是Server版本&#xff09;安装配置Samba&#xff08;Samba是一种Linux和Windows之间进行文件共…

基础知识(王爽老师书第一章)

文章目录 基础知识1.1 引言1.2 机器语言1.2 引言汇编语言的产生1.3 汇编语言的组成1.4 存储器1.5 指令和数据1.6 存储单元1.7 CPU对存储器的读写1.8 地址总线1.9 数据总线1.10 控制总线小结检测点1.11.11 内存地址空间1.12 主板1.13 接口卡1.14 各类存储器芯片1.15 内存地址空间…

【Linux】在Ubuntu中下载jdk以及卸载oraclejdk

介绍 这里是小编成长之路的历程&#xff0c;也是小编的学习之路。希望和各位大佬们一起成长&#xff01; 以下为小编最喜欢的两句话&#xff1a; 要有最朴素的生活和最遥远的梦想&#xff0c;即使明天天寒地冻&#xff0c;山高水远&#xff0c;路远马亡。 一个人为什么要努力&a…

短视频矩阵系统源码/开发技术文档

短视频矩阵系统技术文档&#xff1a; 可以采用电子文档或者纸质文档的形式交付&#xff0c;具体取决于需求方的要求。电子文档可以通过电子邮件、远程指导交付云存储等方式进行传输、 短视频矩阵{seo}源码是指将抖音平台上的视频资源进行筛选、排序等操作&#xff0c;进而提升…

【AcWing刷题】蓝桥杯专题突破-动态规划-dp入门(17)

目录 写在前面&#xff1a; 题目&#xff1a;821. 跳台阶 - AcWing题库 题目描述&#xff1a; 输入格式&#xff1a; 输出格式&#xff1a; 数据范围&#xff1a; 输入样例&#xff1a; 输出样例&#xff1a; 解题思路&#xff1a; 方法一&#xff1a;暴力搜索 代码…

chatgpt赋能Python-pandas_归一化

Pandas归一化是什么&#xff1f; 数据归一化是数据预处理中的一个重要步骤&#xff0c;它能够将不同范围的数值转化为相同的数值范围。Pandas是一种数据处理工具&#xff0c;因此它提供了许多函数来实现数据归一化。其中最常用的函数是Normalization。 Normalization函数的使…

树形结构数据扁平化js方法

最近在公司项目中遇到树形结构数据,在进行遍历查找指定的数据的时候一搬进行递归调用的查询,因为递归是效率很慢的方式,尤其是在数据量特别大的时候是及其浪费性能,所以我想了一个树形结构扁平化的方法,代码如下: /**** param {Array} arrs 树形数据* param {string} childs 树…

Java面向对象程序设计实验报告(实验五 接口的练习)

✨作者&#xff1a;命运之光 ✨专栏&#xff1a;Java面向对象程序设计实验报告 ​ 目录 ✨一、需求设计 ✨二、概要设计 ✨三、详细设计 ✨四、调试结果 ✨五、测试结果 ✨附录&#xff1a;源程序代码&#xff08;带注释&#xff09; demo5类 Instrument类 Piano类 …