- 浏览: 209572 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (196)
- Git (16)
- maven (8)
- Python (20)
- linux (14)
- java (30)
- spring (5)
- javascript (4)
- oracle (15)
- jquery (4)
- jbpm4.4 (4)
- ibatis (1)
- svn (1)
- sql server (1)
- sqoop (1)
- photoshop (2)
- 日常记录 (5)
- scala (1)
- IntelliJ IDEA (7)
- mysql (2)
- Hive (1)
- visual studio code (3)
- angularjs (5)
- nodejs (4)
- gradle (1)
- springboot (4)
- jakson (1)
- hibernate (2)
- 面试 (5)
- React (2)
- Kotlin (1)
- Netty (0)
- webstorm (2)
- spring cloud (4)
- redis (1)
- PowerDesigner (1)
- Vue (4)
- easyui (1)
- activiti (2)
- httpClient4.5 (2)
- logback (3)
- ngrinder (1)
- 分库分表 (1)
最新评论
-
严东军:
学习了,谢谢
摘录--DBMS_SCHEDULER -
zwllxs:
你知道你调的是谁的代码不?
jbpm4.4+ssh2 完整请假流程
git log的常见用法
https://blog.csdn.net/daguanjia11/article/details/73823617
命令形式如下:
git log [] [..] [[--] ...]
git log --pretty=format:"%Cred%h%Creset -%C(yellow)%d%Cblue %s %Cgreen(%cd) %C(bold blue)<%an>"
git log --date=format:'%Y-%m-%d %H:%M:%S' --pretty=format:"%Cred%H %C(yellow)<%cn> %Cgreen%cd %s"
这条命令有很多参数选项
一、不带参数
如果不带任何参数,它会列出所有历史记录,最近的排在最上方,显示提交对象的哈希值,作者、提交日期、和提交说明
如果记录过多,则按Page Up、Page Down、↓、↑来控制显示
按q退出历史记录列表
二、显示参数
-p:按补丁显示每个更新间的差异,比下一条- -stat命令信息更全
--stat:显示每次更新的修改文件的统计信息,每个提交都列出了修改过的文件,以及其中添加和移除的行数,并在最后列出所有增减行数小计
--shortstat:只显示--stat中最后的行数添加修改删除统计
--name-only:尽在已修改的提交信息后显示文件清单
--name-status:显示新增、修改和删除的文件清单
--abbrev-commit:仅显示SHA-1的前几个字符,而非所有的40个字符
--relative-date:使用较短的相对时间显示(例如:"two weeks ago")
--graph:显示ASCII图形表示的分支合并历史
—pretty=:使用其他格式显示历史提交信息,可选项有:oneline,short,medium,full,fuller,email,raw以及format:,默认为medium,如:--pretty=oneline:一行显示,只显示哈希值和提交说明(--online本身也可以作为单独的属性)
--pretty=format:” ":控制显示的记录格式,如:%H 提交对象(commit)的完整哈希字串
%h 提交对象的简短哈希字串
%T 树对象(tree)的完整哈希字串
%t 树对象的简短哈希字串
%P 父对象(parent)的完整哈希字串
%p 父对象的简短哈希字串
%an 作者(author)的名字
%ae 作者的电子邮件地址
%ad 作者修订日期(可以用 -date= 选项定制格式)
%ar 作者修订日期,按多久以前的方式显示
%cn 提交者(committer)的名字作者和提交者的区别不知道是啥?
作者与提交者的关系:作者是程序的修改者,提交者是代码提交人(自己的修改不提交是怎么能让别人拉下来再提交的?)
其实作者指的是实际作出修改的人,提交者指的是最后将此工作成果提交到仓库的人。所以,当你为某个项目发布补丁,然后某个核心成员将你的补丁并入项目时,你就是作者,而那个核心成员就是提交者(soga)
%ce 提交者的电子邮件地址
%cd 提交日期(可以用 -date= 选项定制格式)
%cr 提交日期,按多久以前的方式显示
%s 提交说明
带颜色的--pretty=format:” ",这个另外写出来分析以这句为例:%Cred%h%Creset -%C(yellow)%d%Cblue %s %Cgreen(%cd) %C(bold blue)
它的效果是:
先断句:[%Cred%h][%Creset -][%C(yellow)%d ][%Cblue%s][%Cgreen(%cd)][%C(bold blue)]
然后就是很明显能得到的规律了一个颜色+一个内容
颜色以%C开头,后边接几种颜色,还可以设置字体,如果要设置字体的话,要一块加个括号能设置的颜色值包括:reset(默认的灰色),normal, black, red, green, yellow, blue, magenta, cyan, white.
字体属性则有bold, dim, ul, blink, reverse.
内容可以是占位元字符,也可以是直接显示的普通字符
--date= (relative|local|default|iso|rfc|short|raw):定制后边如果出现%ad或%cd时的日期格式有几个默认选项--date=relative:shows dates relative to the current time, e.g. "2 hours ago".
--date=local:shows timestamps in user’s local timezone.
--date=iso (or --date=iso8601):shows timestamps in ISO 8601 format.
--date=rfc (or --date=rfc2822):shows timestamps in RFC 2822 format,often found in E-mail messages.
--date=short:shows only date but not time, in YYYY-MM-DD format.这个挺好用
--date=raw:shows the date in the internal raw git format %s %z format.
--date=default:shows timestamps in the original timezone (either committer’s or author’s).
也可以自定义格式(需要git版本2.6.0以上),比如--date=format:'%Y-%m-%d %H:%M:%S' 会格式化成:2016-01-13 11:32:13,其他的格式化占位符如下:%a:Abbreviated weekday name
%A:Full weekday name
%b:Abbreviated month name
%B:Full month name
%c:Date and time representation appropriate for locale
%d:Day of month as decimal number (01 – 31)
%H: Hour in 24-hour format (00 – 23)
%I:Hour in 12-hour format (01 – 12)
%j:Day of year as decimal number (001 – 366)
%m:Month as decimal number (01 – 12)
%M:Minute as decimal number (00 – 59)
%p:Current locale's A.M./P.M. indicator for 12-hour clock
%S:Second as decimal number (00 – 59)
%U:Week of year as decimal number, with Sunday as first day of week (00 – 53)
%w:Weekday as decimal number (0 – 6; Sunday is 0)
%W:Week of year as decimal number, with Monday as first day of week (00 – 53)
%x:Date representation for current locale
%X:Time representation for current locale
%y:Year without century, as decimal number (00 – 99)
%Y:Year with century, as decimal number
%z, %Z:Either the time-zone name or time zone abbreviation, depending on registry settings; no characters if time zone is unknown
%%:Percent sign
三、筛选参数:
按数量-n:显示前n条log
按日期--after=比如git log --after="2014-7-1”,显示2014年7月1号之后的commit(包含7月1号)
后边的日期还可以用相对时间表示,比如"1 week ago"和”yesterday",比如git log --after="yesterday"
这里的格式可以是什么?
--before=同上
另外这两条命令可以同时使用表示时间段,比如git log --after="2014-7-1" --before="2014-7-4"
另外--since --until和 --after --before是一个意思,都可以用
按作者--author=比如git log --author=“John",显示John贡献的commit
注意:作者名不需要精确匹配,只需要包含就行了
而且:可以使用正则表达式,比如git log --author="John\|Mary”,搜索Marry和John贡献的commit
而且:这个--author不仅包含名还包含email, 所以你可以用这个搜索email
按commit描述--grep=比如:git log --grep="JRA-224"
而且:可以传入-i用来忽略大小写
注意:如果想同时使用--grep和--author,必须在附加一个--all-match参数
按文件- -(空格)或[没有]有时你可能只对某个文件的修改感兴趣, 你只想查看跟某个文件相关的历史信息, 你只需要插入你感兴趣文件的路径[对,是路径,所以经常是不太好用]就可以了
比如:git log -- foo.py bar.py ,只返回和foo.py或bar.py相关的commit
这里的--是告诉Git后面的参数是文件路径而不是branch的名字. 如果后面的文件路径不会和某个branch产生混淆, 你可以省略- -,比如git log foo.py
另外,后边的路径还支持正则,比如:git log *install.md 是,指定项目路径下的所有以install.md结尾的文件的提交历史
另外,文件名应该放到参数的最后位置,通常在前面加上--并用空格隔开表示是文件
另外,git log file/ 查看file文件夹下所有文件的提交记录
按分支- ---branchName branchName为任意一个分支名字,查看某个分支上的提交记录
需要放到参数中的最后位置处
如果分支名与文件名相同,系统会提示错 误,可通过--选项来指定给定的参数是分支名还是文件名比如:在当前分支中有一个名为v1的文件,同时还存在一个名为v1的分支
git log v1 -- 此时的v1代表的是分支名字(--后边是空的)
git log -- v1 此时的v1代表的是名为v1的文件
git log v1 -- v1 代表v1分支下的v1文件
按内容-S""、-G""有时你想搜索和新增或删除某行代码相关的commit. 可以使用这条命令
假设你想知道Hello, World!这句话是什么时候加入到项目里去的,可以用:git log -S"Hello,World!"
另外:如果你想使用正则表达式去匹配而不是字符串, 那么你可以使用-G代替-S.
这是一个非常有用的debug工具, 使用他你可以定位所有跟某行代码相关的commit. 甚至可以查看某行是什么时候被copy的, 什么时候移到另外一个文件中去的
注:-S后没有"=",与查询内容之间也没有空格符
按范围git log ..这个命令可以查看某个范围的commit
这个命令非常有用当你使用branch做为range参数的时候. 能很方便的显示2个branch之间的不同
比如:git log master..feature,master..feature这个range包含了在feature有而在master没有的所有commit,同样,如果是feature..master包含所有master有但是feature没有的commit
另外,如果是三个点,表示或的意思:git log master...test 查询master或test分支中的提交记录
过滤掉merge commit--no-merges默认情况下git log会输出merge commit. 你可以通过--no-merges标记来过滤掉merge commit,git log --no-merges
另外,如果你只对merge commit感兴趣可以使用—merges,git log --merges
按标签taggit log v1.0直接这样是查询标签之前的commit
加两个点git log v1.0.. 查询从v1.0以后的提交历史记录(不包含v1.0)
按commitgit log commit :查询commit之前的记录,包含commit
git log commit1 commit2:查询commit1与commit2之间的记录,包括commit1和commit2
git log commit1..commit2:同上,但是不包括commit1其中,commit可以是提交哈希值的简写模式,也可以使用HEAD代替HEAD代表最后一次提交,HEAD^为最后一个提交的父提交,等同于HEAD~1
HEAD~2代表倒数第二次提交
发表评论
-
git revert
2018-09-26 17:46 458git revert HEAD 使用git reset回退公共 ... -
git tag
2017-06-30 16:24 494Git 中的tag指向一次commit的id,通常用来给开发 ... -
Windows下使用Beyond Compare作为git的比对与合并工具
2017-05-26 15:29 567Windows下使用Beyond Compare作为git的比 ... -
Git代码行统计命令集
2016-12-07 15:35 419转载:https://segmentfault.com/a/1 ... -
配置KDiff3作为GIT merge图形化工具
2016-12-06 15:53 1131配置KDiff3作为GIT merge图形化工具 1. 安 ... -
git stash
2016-12-02 11:02 481转载:http://blog.csdn.net/qinjien ... -
git log 查看提交记录
2016-11-03 17:47 991git log 查看提交记录, ... -
git 优秀博文
2016-08-19 17:51 517常用 Git 命令总结 http://www ... -
linux 安装git
2016-08-05 11:11 368在CentOS5的时代,由于yum源中没有git,所以需要预先 ... -
git diff命令详解
2016-07-11 10:47 582diff里面a表示前面那个变量,b表示第二个变量 HEAD ... -
Git 项目不显示repo小图标
2016-05-11 09:21 624正常git项目被eclipse git插件管理时, 不显 ... -
Git操作详解
2016-05-11 09:21 569手把手教你使用Git ... -
Git 分支操作
2016-05-11 09:23 3561.查看所有分支 git branch -a ... -
Git常用命令总结
2016-05-11 09:22 430http://blog.bcmeng.com/post/git ... -
You have not concluded your merge (MERGE_HEAD exis
2016-05-13 10:28 849今天获取git线上仓库代码报了这个错误: zhan ...
相关推荐
5. **集成到构建流程**:在前端项目中,Gitlog 可以集成到自动化构建流程中,用于生成 Changelog 文件,自动记录每次发布版本的主要变更,提高项目的透明度。 6. **与其他工具的兼容性**:由于 Gitlog 是基于 Node....
在Git中,`git log`是一个极其重要的命令,用于查看项目的历史提交记录。本篇文章将详细阐述`git log`的使用及其常见参数,帮助你更好地理解和利用这个功能。 1. **基本使用**: 当你运行`git log`命令时,它会列...
Git Log 查询命令是 Git 版本控制系统中的一组命令,用于查询和统计代码提交记录,提高开发和管理效率。下面是 Git Log 查询命令的详细说明: 一、格式化输出 Git Shortlog 命令是 Git Log 命令的一种特殊形式,...
git-log-to-json 在json中打印可配置的git日志 安装 $ npm install git-log-to-json 命令行界面 Usage: git-log-to-json|git log-to-json Print a configurable git log in json Options: -h, --help output ...
在使用Git时,我们还需要了解 Git log 命令,这是一个非常有用的命令,用于查看项目的提交历史记录。例如,git log 命令可以显示当前分支的所有提交记录,包括提交的作者、日期、提交信息等等。 此外,我们还需要...
【Git教程——查看修改日志 (log & diff)】 在Git这个版本控制系统中,每一次对文件的修改都会被单独保存并记录为一个提交(commit)。这些提交就像建筑楼房时的一块块砖石,它们共同构成了项目的整个历史。通过Git...
要切换到特定版本,你需要知道对应的commit ID,可以通过`git log`获取,然后执行`git reset --hard commit_id`。 在工作区进行修改后,`git status`会提示你哪些文件有变更。若想撤销工作区的某个修改,而不进行...
- 使用`git log`命令可以查看提交历史,包括每次提交的版本号(commit id)、作者、提交时间等信息。 - 可以使用`git log --pretty=oneline`简化输出,使信息更加简洁易读。 2. **版本回退**: - Git中的版本回退...
git 基本命令整合 Git基本常用命令如下: git init 把当前的目录变成可以管理的git仓库,生成隐藏.... git log 查看历史记录 git reset --hard HEAD^ git reset --hard HEAD git文件版本号 回退到上一个版本
17. **查看文件历史**:`git log --pretty=oneline -- filename`列出文件历史,`git show xxxxx:filename`查看特定版本的内容,`git diff xxxx1 xxxx2 -- filename`对比两个版本差异。 18. **回退版本**:`git ...
1. 使用`git log`命令可以查看Git仓库的提交历史。执行这个命令会显示所有提交的详细信息,包括作者、日期和提交信息等。 2. `git log`命令有多种选项可以定制输出: - `git log --oneline`:以一行的形式简洁...
通过`git log`命令可以查看这些历史。 5. 高效性能:Git的设计使其在处理大量文件和历史记录时仍能保持高效。 6. 撤销更改:如果误操作,Git提供了多种方式恢复到之前的版本,如`git reset`和`git revert`。 7. ...
在Git中,你可以轻松地查看历史版本、回退到特定版本、比较不同版本之间的差异,甚至可以合并两个分支的代码。它还支持分支(Branch)和合并(Merge),允许开发者在不同的分支上并行开发,然后将各自的工作整合在...
9. **测试安装**:安装完成后,可以通过在命令行输入`git --version`来检查Git是否安装成功并查看版本信息。 Git的基本命令和操作包括: - `git clone`:克隆远程仓库到本地。 - `git add`:将文件添加到暂存区,...
9. **版本回溯**:通过`git log`和`git blame`,你可以追踪文件的历史改动,找出问题的来源。 10. **工作流**:理解不同的Git工作流模式,如Git Flow、GitHub Flow等,可以帮助团队更高效地协作。 "Pro Git中文...
* `git log` 命令用于查看版本库的提交记录。 * `git reset` 命令用于将文件回退到之前的版本。 * `git reflog` 命令用于查看版本库的命令记录。 三、 Git 文件管理 * Git 可以管理文件的变化,包括添加、删除和...
**4.6 git查看历史记录** - **命令**:`git log` - **作用**:查看提交历史记录。 #### 五、git发布补丁和打补丁 **5.1 git创建补丁** - **命令**:`git format-patch <commit>` - **作用**:根据指定的提交创建...
在Git仓库管理中,有时出于隐私、安全或者代码版本重置等需求,我们可能需要清除commit历史记录,将仓库恢复到初次commit的状态。这个过程涉及到对Git仓库的深入操作,包括创建新分支、添加文件、删除旧分支以及强制...
此外,Git还提供了丰富的命令来查看和追溯代码的历史,如`git log`显示提交日志,`git blame`追踪每一行代码的修改者,`git diff`比较不同版本之间的差异。对于协同开发,`git clone`用于复制远程仓库,`git pull`...
建立儲存庫是Git版本控管的基础, Git倉儲庫可以存储项目的所有版本历史记录。 知识点4:常用的Git版本控管指令 Git版本控管中有许多常用的指令,例如add、commit、log、status、branch等。 知识点5:了解儲存庫、...