#showprpduct 在使用git pull代码时,经常会碰到有冲突的情况,提示如下信息:
error: Your local changes to 'c/environ.c' would be overwritten by merge. Aborting. Please, commit your changes or stash them before you can merge. 这个意思是说更新下来的内容和本地修改的内容有冲突,先提交你的改变或者先将本地修改暂时存储起来。
处理的方式非常简单,主要是使用git stash命令进行处理,分成以下几个步骤进行处理。
1、先将本地修改存储起来
$ git stash 这样本地的所有修改就都被暂时存储起来 。是用git stash list可以看到保存的信息:
git stash暂存修改 git stash暂存修改
其中stash@{0}就是刚才保存的标记。
2、pull内容
暂存了本地修改之后,就可以pull了。
$ git pull 3、还原暂存的内容
$ git stash pop stash@{0} 系统提示如下类似的信息:
Auto-merging c/environ.c CONFLICT (content): Merge conflict in c/environ.c 意思就是系统自动合并修改的内容,但是其中有冲突,需要解决其中的冲突。
4、解决文件中冲突的的部分
打开冲突的文件,会看到类似如下的内容:
git冲突内容 git冲突内容
其中Updated upstream 和=====之间的内容就是pull下来的内容,====和stashed changes之间的内容就是本地修改的内容。碰到这种情况,git也不知道哪行内容是需要的,所以要自行确定需要的内容。 解决完成之后,就可以正常的提交了。
先看个例子:
仅仅想看最近谁有提交,以及提交的描述 对应命令 gitlog 显示Sample
commit6305aa81a265f9316b606d3564521c43f0d6c9a3 Author:XXX Date: Thu Nov 3 11:38:15 2011 +0800 fillauthor information in the head of files and format some code commit8e8a4a96e134dab8f045937efee35bd710006946 Author:XXX Date: Thu Nov 3 04:05:34 2011 +0800 usermanagement is mostly complete details: add support for account disable/enable rewrite most related views to suit the above need provide two decorators for access control (see README) fixed many errors in Milestone 1 commit2870cd564371d8ad043d0da426a5770d36412421 Author:XXX Date: Mon Oct 17 20:19:04 2011 -0400 fixthe bug of get_ori_url_from_shorturl(). commitb6cdd881a19ecaff838d5825c3a6b7058fdd498a Author:XXX Date: Mon Oct 17 20:17:37 2011 -0400 fixthe bug of get_article_from_short_url. 仅仅想看最后一次的提交 对应命令参数-n1 显示Sample commit6305aa81a265f9316b606d3564521c43f0d6c9a3 Author: XXX Date:Thu Nov 3 11:38:15 2011 +0800 fillauthor information in the head of files and format some code 想看到最近一次提交所有更改过的文件 对应命令 gitlog -n 1 --stat 显示Sample
commit6305aa81a265f9316b606d3564521c43f0d6c9a3 Author:XXX Date: Thu Nov 3 11:38:15 2011 +0800 fillauthor information in the head of files and format some code Site/accounts/decorators.py | 2+- Site/accounts/forms.py | 1+ Site/accounts/models.py | 1+ Site/accounts/readme | 3++- Site/accounts/templates/account_activate.html | 1+ Site/accounts/templates/account_disabled.html | 1 + … … 28files changed, 37 insertions(+), 8 deletions(-) 想看到最近一次提交所有更改的细节 对应命令 gitlog -n 1 -p 显示Sample
commit6305aa81a265f9316b606d3564521c43f0d6c9a3 Author:XXX Date: Thu Nov 3 11:38:15 2011 +0800 fillauthor information in the head of files and format some code diff--git a/Site/accounts/decorators.pyb/Site/accounts/decorators.py index 22522bc..a6bb440100755 --- a/Site/accounts/decorators.py +++b/Site/accounts/decorators.py @@ -1,9 +1,9@@ #!/usr/bin/env python
+# author: Rex Nov. 3, 2011 from functoolsimport wraps from django.core.urlresolvers importreverse from django.http import HttpResponseRedirect -fromdjango.utils.decorators import available_attrs fromSite.accounts.models import UserProfile deflogin_required(view_func): diff --gita/Site/accounts/forms.py b/Site/accounts/forms.py index016710b..778d92a 100755 --- a/Site/accounts/forms.py +++b/Site/accounts/forms.py @@ -1,5 +1,6 @@ #!/usr/bin/envpython
+# author: Rex Nov.3, 201 … …
1.git log
如果不带任何参数,它会列出所有历史记录,最近的排在最上方,显示提交对象的哈希值,作者、提交日期、和提交说明。如果记录过多,则按Page Up、Page Down、↓、↑来控制显示;按q退出历史记录列表。git log命令后的例子:
commit6305aa81a265f9316b606d3564521c43f0d6c9a3 Author:XXX Date: Thu Nov 3 11:38:15 2011 +0800 fillauthor information in the head of files and format some code commit8e8a4a96e134dab8f045937efee35bd710006946 Author:XXX Date: Thu Nov 3 04:05:34 2011 +0800 usermanagement is mostly complete details: add support for account disable/enable rewrite most related views to suit the above need provide two decorators for access control (see README) fixed many errors in Milestone 1 commit2870cd564371d8ad043d0da426a5770d36412421 Author:XXX Date: Mon Oct 17 20:19:04 2011 -0400 fixthe bug of get_ori_url_from_shorturl(). commitb6cdd881a19ecaff838d5825c3a6b7058fdd498a Author:XXX Date: Mon Oct 17 20:17:37 2011 -0400 fixthe bug of get_article_from_short_url.
2.git log -n
如果不想向上面那样全部显示,可以选择显示前N条。
想看到最近一次提交所有更改过的文件 git -n 1 显示Sample commit6305aa81a265f9316b606d3564521c43f0d6c9a3 Author: XXX Date:Thu Nov 3 11:38:15 2011 +0800 fillauthor information in the head of files and format some code
3.git log --stat -n
显示简要的增改行数统计,每次提交文件的变更统计,-n 同上,前n条,可省略。
$ git log --stat -2 commit d0b9a20fac8abc7517c5a04c0fbb1d488f309bf5 Author: BeginMan pythonsuper@gmail.com Date: Sat Mar 1 23:26:43 2014 +0800
ok
_posts/2014-02-27-Customizing-Git.md | 5 +++++ 1 file changed, 5 insertions(+)
commit 8c186cd71492b7a3eae6df7de880b99efa0f87cf Author: BeginMan pythonsuper@gmail.com Date: Sat Mar 1 23:26:10 2014 +0800
mi
_posts/2014-02-27-Customizing-Git.md | 56 +++++++++++++++++++++++++++++++++++- 1 file changed, 55 insertions(+), 1 deletion(-) 每个提交都列出了修改过的文件,以及其中添加和移除的行数,并在最后列出所有增减行数小计,比如上面的有5行做了更新。
4.git log -p -n
此命令同上,不过显示更全了。
5.git log --pretty=oneline
一行显示,只显示哈希值和提交说明。
6.gig lot --graph
ASCII 字符串表示的简单图形,形象地展示了每个提交所在的分支及其分化衍合情况
$ git log --pretty=format:"%h %s" --graph 7.$ git log --pretty=format:" "
控制显示的记录格式,常用的格式占位符写法及其代表的意义如下:
选项 说明 %H 提交对象(commit)的完整哈希字串 %h 提交对象的简短哈希字串 %T 树对象(tree)的完整哈希字串 %t 树对象的简短哈希字串 %P 父对象(parent)的完整哈希字串 %p 父对象的简短哈希字串 %an 作者(author)的名字 %ae 作者的电子邮件地址 %ad 作者修订日期(可以用 -date= 选项定制格式) %ar 作者修订日期,按多久以前的方式显示 %cn 提交者(committer)的名字 %ce 提交者的电子邮件地址 %cd 提交日期 %cr 提交日期,按多久以前的方式显示 %s 提交说明 如下操作:
$ git log --pretty=format:"%h -%an,%ar : %s" -3 d0b9a20 -BeginMan,24 hours ago : ok 8c186cd -BeginMan,24 hours ago : mi b2a3100 -BeginMan,24 hours ago : what? 显示了前3条的信息,简单的哈希值,作者,提交时间,提交说明。
个人感觉这个命令挺好的,为了方面使用,还是做个别名吧:
$ git config alias.logs "log --pretty=format:'%h -%an,%ar:%s'" $ git config alias.logs log --pretty=format:'%h -%an,%ar:%s' $ git logs .... 8.指定路径
比如说,指定项目路径下的所有以install.md结尾的文件的提交历史:
$ git log --pretty=oneline *install.md 只需要加上文件路径作为参数即可。
9.指定日期、关键字、作者
如两天前的提交历史:git log --since=2.days
如指定作者为"BeginMan"的所有提交:$ git log --author=BeginMan
如指定关键字为“init”的所有提交:$ git log --grep=init
如指定提交者为"Jack"的所有提交:$ git log --committer=Jack
注意作者与提交者的关系:作者是程序的修改者,提交者是代码提交人。
如指定2天前,作者为“BeginMan”的提交含有关键字'init'的前2条记录:$ git log --since=2.days --author=BeginMan --grep=init -2
注意:上面选项后面的参数可以带单双引号,如--author="BeginMan"
使用说明如下:
选项 说明
-(n) 仅显示最近的 n 条提交
--since, --after 仅显示指定时间之后的提交。
--until, --before 仅显示指定时间之前的提交。
--author 仅显示指定作者相关的提交。
--committer 仅显示指定提交者相关的提交。
来看一个实际的例子,如果要查看 Git 仓库中,2008 年 10 月期间,Junio Hamano 提交的但未合并的测试脚本(位于项目的 t/ 目录下的文件),可以用下面的查询命令:
$ git log --pretty="%h - %s" --author=gitster --since="2008-10-01"
--before="2008-11-01" --no-merges -- t/
如果了解更多关于git grep可以参考这里
参考:
git log 命令支持的选项
-p 按补丁格式显示每个更新之间的差异。
--stat 显示每次更新的文件修改统计信息。
--shortstat 只显示 --stat 中最后的行数修改添加移除统计。
--name-only 仅在提交信息后显示已修改的文件清单。
--name-status 显示新增、修改、删除的文件清单。
--abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符。
--relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)。
--graph 显示 ASCII 图形表示的分支合并历史。
--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)。
10.git 图形客户端的使用
使用gitk图形客户端查看历史记录。输入$ gitk即可打开,如下:
如果是Linux平台下,可推荐如下:
linux 下6款 git 图形客户端
11.终极之道
终极之道就是查看帮助,如下打开文档查看,前提是英文要好。
$ git log --help Launching default browser to display HTML ...
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。