但默认命令显示出的x效果实在太丑,不好好打扮一下根本没法见人,打扮好了用命令拍个照片,就正式出道了!
1、命令说明
git log [<options>] [<since>..<until>] [[--] <path>...]
默认的命令显示效果如下:
2、命令参数
这条命令有很多参数选项,下面详细的说明:
(1)不带参数
如果不带任何参数,它会列出所有历史记录,最近的排在最上方,显示提交对象的哈希值,作者、提交日期、和提交说明。
如果记录过多,则按,(向下显示一行),(显示下一页),来控制显示。
按键退出历史记录列表。
(2)常用显示参数
:按补丁格式显示每个更新的差异,比下一条命令信息更全。
:显示每次提交修改文件的统计信息,每个提交都列出了修改过的文件,以及其中添加和移除的行数,并在最后列出所有增减行数小计。
:只显示中最后的行数添加、修改、删除的统计。
:仅在提交信息后,显示已修改的文件清单。
:显示新增、修改、删除的文件清单。
:仅显示校验和的前几个字符,而非所有的40个字符。
:使用较短的相对时间,而不是完整格式显示日期(比如)。
:在日志旁以图形显示分支与合并历史。
:列表的形式查看历史版本记录,合用的简写。
:使用其他格式显示历史提交信息。可用的选项包括、、、和 (用来定义自己的格式)。
(3)参数
选项有:
2):控制显示信息的格式。
序号 | 格式 | 说明 |
---|---|---|
1 | 提交的完整哈希值()。 | |
2 | 提交的简写哈希值。 | |
3 | 树的完整哈希值()。 | |
4 | 树的简写哈希值。 | |
5 | 父提交()的完整哈希值。 | |
6 | 父提交的简写哈希值。 | |
7 | 作者名字()。 | |
8 | 作者的电子邮件地址。 | |
9 | 作者修订日期(可以用 选项 来定制格式)。 | |
10 | 作者修订日期,按多久以前的方式显示。 | |
11 | 提交者的名字()。 | |
12 | 提交者的电子邮件地址。 | |
13 | 提交日期(可以用 选项 来定制格式)。 | |
14 | 提交日期,按多久以前的方式显示。 | |
15 | 提交说明。 |
颜色格式:
%Cred:将颜色切换为红色。
%Cgreen:将颜色切换为绿色。
%Cblue:将颜色切换为蓝色。
%Creset:空格。
举例:
执行命令:
两种效果如下:我们先进行断句分析:
然后就是很明显能得到的规律了:
写法:一个颜色+一个内容,例如,依次排写。
颜色以开头,后边接几种颜色,还可以设置字体,如果要设置字体的话,要一块加个括号。
能设置的颜色值包括:(默认的灰色),,,,,,,,,。(不能单独使用就加括号)
字体属性则有,,,,。
内容可以是占位元字符,也可以是直接显示的普通字符(例如上面的)。
(4)参数
有几个默认选项:
:显示相对于当前时间的日期,例如"2小时前"。
:显示用户本地时区中的时间戳。
或:以格式显示时间戳。
或:以格式显示时间戳,通常在电子邮件中找到。
:仅以格式显示日期,而不显示时间。
:以内部原始Git格式格式显示日期。
:显示原始时区(提交者或作者)的时间戳。
也可以自定义格式(需要Git版本2.6.0以上):
其他的格式化占位符如下:
:星期的缩写。
:星期的全名。
:月份的缩写。
:月份的全称。
:适用于区域设置的日期和时间表示。
:月中的天作为十进制数字(01 – 31)。
: 24小时制的小时(00 – 23)。
:2小时格式的小时(01 – 12)。
:一年中的天作为十进制数字(001 – 366)。
:以十进制数字表示的月份(01 – 12)。
:分钟以十进制数字表示(00 – 59)。
:当前语言环境的"上午/下午",12小时制的指示器。
:秒作为十进制数字(00 – 59)。
:一年中的周为十进制数字,周日为一周的第一天(00 – 53)。
:工作日为十进制数字(0 – 6;星期日为0)。
:一年中的星期作为十进制数字,星期一作为星期的第一天(00 – 53)
:当前语言环境的日期表示。
:当前语言环境的时间表示。
:无世纪的年份,为十进制数字(00 – 99),也就是年份没有前两位。
:带世纪的年份,以十进制数表示。
,:时区名称或时区缩写,取决于注册表设置; 如果时区未知,则没有字符。
:表示百分号。
(5)筛选参数
1)按数量
:显示前n条提交信息。
2)按日期
比如,显示2014年7月1号之后的(包含7月1号)。
后边的日期还可以用相对时间表示,比如和,比如。
:同上。
同理:、和、是一个意思。
, :仅显示指定时间之前的提交。
3)按作者和提交者
比如,显示贡献的。
注意:作者名不需要精确匹配,只需要包含就行了。
而且可以使用正则表达式,比如,搜索和贡献的。
而且这个不仅包含作者名,还包含作者的,所以你可以用这个搜索。
:仅显示提交者匹配指定字符串的提交。
4)按commit描述
比如:
而且可以传入用来忽略大小写。
注意:如果想同时使用和,必须在附加一个参数。
5)按文件
有时你可能只对某个文件的修改感兴趣,或你只想查看跟某个文件相关的历史信息,你只需要插入你感兴趣文件的路径,[对,是路径,所以经常是不太好用]就可以了。
比如:,只返回和文件或文件的相关。
这里的是告诉Git,后面的参数是文件路径而不是(分支)的名字。 如果后面的文件路径不会和某个产生混淆,你可以省略,比如。
另外,后边的路径还支持正则,比如:,是指定项目路径下的所有以结尾文件的提交历史。
另外,文件名应该放到参数的最后位置,通常在前面加上并用空格隔开表示是文件。
另外,,可以查看文件夹下所有文件的提交记录。
6)按分支
参数:为任意一个分支名字,查看某个分支上的提交记录。
需要放到参数中的最后位置处。
如果分支名与文件名相同,系统会提示错误,可通过选项,来指定给定的参数,是分支名还是文件名。
比如:在当前分支中有一个名为v1的文件,同时还存在一个名为v1的分支。如下:
,此时的v1代表的是分支名字(后边是空的)。
,此时的v1代表的是名为v1的文件。
:代表v1分支下的v1文件。
7)按内容
有时你想搜索,新增或删除某行代码相关的. 可以使用这条命令。
假设你想知道这句话,是什么时候加入到项目里去的,可以用:。
另外,如果你想使用正则表达式去匹配,而不是字符串,那么你可以使用代替。
这是一个非常有用的工具,使用他可以定位所有跟某行代码相关的,甚至可以查看某行是什么时候被的,什么时候移到另外一个文件中去的。
注意:后没有,与查询内容之间也没有空格符。
8)按范围
这个命令可以查看某个范围的。
这个命令非常有用当你使用做为参数的时候. 能很方便的显示2个(分支)之间的不同。
比如:,这个(范围),包含了在分支存在,而在分支没有的所有。同样,如果是,意思是包含所有分支有,但是分支没有的。
另外,如果是三个点,表示或的意思:,意思是查询或分支中的提交记录。
9)过滤掉merge commit
默认情况下会输出(合并提交)。你可以通过标记来过滤掉,例如:。
另外,如果你只对感兴趣可以使用参数,例如:。
10)按标签tag
直接这样是查询标签之前的。
加两个点,例如:,是查询从以后的提交历史记录(不包含v1.0)。
11)按commit
:查询之前的记录,包含。
:查询与之间的记录,包括和。
:同上,但是不包括。
其中,可以是提交哈希值的简写模式,也可以使用HEAD代替。
HEAD代表最后一次提交,为最后一个提交的父提交,等同于。
代表倒数第二次提交。
提示:Git的指令是非常丰富的,通过 或者,可以以浏览器的方式查看更多关于的指令。