在使用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暂存修改


其中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冲突内容



其中Updated upstream 和=====之间的内容就是pull下来的内容,====和stashed changes之间的内容就是本地修改的内容。碰到这种情况,git也不知道哪行内容是需要的,所以要自行确定需要的内容。

解决完成之后,就可以正常的提交了。




先看个例子:

仅仅想看最近谁有提交,以及提交的描述

对应命令 gitlog

显示Sample

 

commit6305aa81a265f9316b606d3564521c43f0d6c9a3 
 Author:XXX 
 Date:   Thu Nov 3 11:38:15 2011 +0800fillauthor information in the head of files and format some code
commit8e8a4a96e134dab8f045937efee35bd710006946 
 Author:XXX 
 Date:   Thu Nov 3 04:05:34 2011 +0800usermanagement 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 1commit2870cd564371d8ad043d0da426a5770d36412421 
 Author:XXX 
 Date:   Mon Oct 17 20:19:04 2011 -0400fixthe bug of get_ori_url_from_shorturl().
commitb6cdd881a19ecaff838d5825c3a6b7058fdd498a 
 Author:XXX 
 Date:   Mon Oct 17 20:17:37 2011 -0400fixthe bug of get_article_from_short_url.

仅仅想看最后一次的提交

对应命令参数-n1

显示Sample

commit6305aa81a265f9316b606d3564521c43f0d6c9a3 
 Author: XXX 
 Date:Thu Nov 3 11:38:15 2011 +0800fillauthor 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 +0800fillauthor 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 +0800fillauthor 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 
 # -*- coding: utf-8-*- 
 +# 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 UserProfiledeflogin_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 
 # -*- coding: utf-8 -*- 
 +# 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 +0800fillauthor information in the head of files and format some code
commit8e8a4a96e134dab8f045937efee35bd710006946 
 Author:XXX 
 Date:   Thu Nov 3 04:05:34 2011 +0800usermanagement 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 1commit2870cd564371d8ad043d0da426a5770d36412421 
 Author:XXX 
 Date:   Mon Oct 17 20:19:04 2011 -0400fixthe bug of get_ori_url_from_shorturl().
commitb6cdd881a19ecaff838d5825c3a6b7058fdd498a 
 Author:XXX 
 Date:   Mon Oct 17 20:17:37 2011 -0400fixthe 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 +0800fillauthor 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 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即可打开,如下:


Android 遍历文件夹中办公文件 android 文件列表_python

如果是Linux平台下,可推荐如下:


Android 遍历文件夹中办公文件 android 文件列表_Android 遍历文件夹中办公文件_02

11.终极之道

终极之道就是查看帮助,如下打开文档查看,前提是英文要好。

$ git log --help
Launching default browser to display HTML ...