本文总结了git常用的命令,以便学习者使用时查阅~

 

几个专用名词的译名如下

  • Workspace:工作区
  • Index / Stage:暂存区
  • Repository:仓库区(或本地仓库)
  • Remote:远程仓库

复制一个已创建的仓库:

git clone ssh://user@domain.com/repo.git

创建一个新的本地仓库:

git init

显示工作路径下已修改的文件:

git status

显示与上次提交版本文件的不同:

git diff

把当前所有修改添加到下次提交中:

git add

把对某个文件的修改添加到下次提交中:

git add -p <file>

提交本地的所有修改:

git commit -a

提交之前已标记的变化:

git commit

附加消息提交:

git commit -m 'message here'

提交,并将提交时间设置为之前的某个日期:

git commit --date="`date --date='n day ago'`" -am "Commit Message"

修改上次提交
请勿修改已发布的提交记录!

git commit --amend

把当前分支中未提交的修改移动到其他分支

git stash
git checkout branch2
git stash pop

列出所有stash

git stash list

查看一个stash

git show stash@{}

删除一个stash

git stash drop stash@{}

将指定的stash取出来

git stash apply stash@{}

将最后一个stash取出来,并删除掉队列中相应的值

git stash pop 

清空所有stash

git stash clear

从当前目录的所有文件中查找文本内容:

git grep "Hello"

在某一版本中搜索文本:

git grep "Hello" v2.

从最新提交开始,显示所有的提交记录(显示hash, 作者信息,提交的标题和时间):

git log

显示所有提交(仅显示提交的hash和message):

git log --oneline

显示某个用户的所有提交:

git log --author="username"

显示某个文件的所有修改:

git log -p <file>

谁,在什么时间,修改了文件的什么内容:

git blame <file>

列出所有的分支:

git branch

列出所有的分支以及其对应的远端分支:

git branch -vv

切换分支:

git checkout <branch>

创建并切换到新分支:

git checkout -b <branch>

基于当前分支创建新分支:

git branch <new-branch>

基于远程分支创建新的可追溯的分支:

git branch --track <new-branch> <remote-branch>

删除本地分支:

git branch -d <branch>

给当前版本打标签:

git tag <tag-name>

获取本地标签:

git tag

删除一个本地标签:

git tag -d <tag-name>

删除一个远端标签:

git push origin :refs/tags/<tag-name>

发布标签:

git push --tags

列出当前配置的远程端:

git remote -v

显示远程端的信息:

git remote show <remote>

添加新的远程端:

git remote add <remote> <url>

下载远程端版本,但不合并到HEAD中:

git fetch <remote>

下载远程端版本,并自动与HEAD版本合并:

git remote pull <remote> <url>

将远程端版本合并到本地版本中:

git pull origin master

将本地版本发布到远程端:

git push remote <remote> <branch>

将本地branch1发布到远程端branch2:

git push origin <branch1>:<branch2>

删除远程端分支:

git push <remote> :<branch> (since Git v1.5.0)
git push <remote> --delete <branch> (since Git v1.7.0)

将分支合并到当前HEAD中:

git merge <branch>

将当前HEAD版本重置到分支中:
请勿重置已发布的提交!

git rebase <branch>

退出重置:

git rebase --abort

解决冲突后继续重置:

git rebase --continue

使用配置好的merge tool 解决冲突:

git mergetool

在编辑器中手动解决冲突后,标记文件为已解决冲突

git add <resolved-file>
git rm <resolved-file>

两个分支的合并,将other-branch合并到main-branch中

git checkout <other-branch>
git rebase <main-branch>
git checkout <main-branch>
git merge <other-branch>

放弃工作目录下的所有修改:

git reset --hard HEAD

移除缓存区的所有文件(i.e. 撤销上次git add):

git reset HEAD

放弃某个文件的所有本地修改:

git checkout HEAD <file>

重置一个提交(通过创建一个截然不同的新提交)

git revert <commit>

将HEAD重置到指定的版本,并抛弃该版本之后的所有修改:

git reset --hard <commit>

将HEAD重置到上一次提交的版本,并将之后的修改标记为未添加到缓存区的修改:

git reset <commit>

将HEAD重置到上一次提交的版本,并保留未提交的本地修改:

git reset --keep <commit>

最后附一张完整展示git流程的图片

参考:

http://www.codeceo.com/article/git-command-guide.html

http://www.ruanyifeng.com/blog/2014/06/git_remote.html

http://git-scm.com/doc

简明 Git 命令速查表的更多相关文章

  1. 简明 Git 命令速查表(中文版)

    原文引用地址:https://github.com/flyhigher139/Git-Cheat-Sheet/blob/master/Git%20Cheat%20Sheet-Zh.md在Github上 ...

  2. Git 命令速查表

    Git 命令速查表 1.常用的Git命令 命令 简要说明 git add 添加至暂存区 git add-interactive 交互式添加 git apply 应用补丁 git am 应用邮件格式补丁 ...

  3. Git命令速查表【转】

    本文转载自:http://www.cnblogs.com/kenshinobiy/p/4543976.html 一. Git 常用命令速查 git branch 查看本地所有分支git status ...

  4. Git命令速查表

  5. Git 常用命令速查表(图文+表格)

    一. Git 常用命令速查 git branch 查看本地所有分支git status 查看当前状态 git commit 提交 git branch -a 查看所有的分支git branch -r ...

  6. Git 常用命令速查表(图文+表格)【转】

    转自:http://www.jb51.net/article/55442.htm 一. Git 常用命令速查 git branch 查看本地所有分支git status 查看当前状态 git comm ...

  7. Git常用命令速查表 & Git Basics & github : release 发布!

    Git常用命令速查表 & Git Basics  & github : release  发布! Git常用命令速查表: 1 1 1 1 1 http://git-scm.com/bo ...

  8. GNU Emacs命令速查表

    GNU Emacs命令速查表 第一章  Emacs的基本概念 表1-1:Emacs编辑器的主模式 模式 功能 基本模式(fundamental mode) 默认模式,无特殊行为 文本模式(text m ...

  9. VIM 命令速查表

    今天整理一份 VIM 常用命令速查表,当做给自己备忘. 进入VIM 相关 命令 描述 vim filename 打开或者新建文件 vim +n filename 打开文件并将光标置于第n行行首 vim ...

随机推荐

  1. javadoc错误: 编码gbk的不可映射字符

    在使用Eclipse进行javadoc的导出时,提示“编码 GBK 的不可映射字符”,应该就是中文注释Eclipse不认,需要在调用javadoc.exe的时候传递编码集告诉它采用什么编码去生成jav ...

  2. CA Loves GCD (BC#78 1002) (hdu 5656)

    CA Loves GCD  Accepts: 135  Submissions: 586  Time Limit: 6000/3000 MS (Java/Others)  Memory Limit: ...

  3. Redis主从复制深入剖析

    Redis是一个开源的,遵守BSD许可协议的key/value缓存系统,并由其高效的响应速度以及丰富的数据结构而闻名.Redis在京东的使用也是非常普遍的,包括很多关键业务上的 使用,由于Redis官 ...

  4. C++混合编程之idlcpp教程Lua篇(9)

    上一篇在这 C++混合编程之idlcpp教程Lua篇(8) 第一篇在这 C++混合编程之idlcpp教程(一) 与前面的工程相比,工程LuaTutorial7中除了四个文件LuaTutorial7.c ...

  5. 无线安全专题_攻击篇--MAC泛洪攻击

    上一篇讲解了无线安全专题_攻击篇--干扰通信,没在首页待多长时间就被拿下了,看来之后不能只是讲解攻击实战,还要进行技术原理和防御方法的讲解.本篇讲解的是局域网内的MAC泛洪攻击,这种攻击方式主要目的是 ...

  6. ABP框架Web API跨域问题的解决方案

    ​1.在Web Api 项目下安装 Microsoft.AspNet.WebApi.Cors 包 Install-Package Microsoft.AspNet.WebApi.Cors 2.在Web ...

  7. 【腾讯Bugly干货分享】腾讯验证码的十二年

    本文来自于腾讯bugly开发者社区,未经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/581301b146dfb1456904df8d Dev Club 是一个交流移动 ...

  8. Java提高篇(二八)------TreeSet

    与HashSet是基于HashMap实现一样,TreeSet同样是基于TreeMap实现的.在<Java提高篇(二七)-----TreeMap>中LZ详细讲解了TreeMap实现机制,如果 ...

  9. Java提高篇(二七)-----TreeMap

    TreeMap的实现是红黑树算法的实现,所以要了解TreeMap就必须对红黑树有一定的了解,其实这篇博文的名字叫做:根据红黑树的算法来分析TreeMap的实现,但是为了与Java提高篇系列博文保持一致 ...

  10. VS 2008 生成操作中各个选项的差别

    近日,在编译C#项目时经常发现有些时候明明代码没错,但就是编译不过,只有选择重新编译或者清理再编译才会不出错,本着求学的态度,搜罗了下VS2008IDE中生成操作的种类以及差别,整理如下:   内容( ...