文/阮一峰

  我每天使用 Git ,但是很多命令记不住。

  一般来说,日常使用只要记住下图 6 个命令,就可以了。但是熟练使用,恐怕要记住 60~100 个命令。

  下面是我整理的常用 Git 命令清单。几个专用名词的译名如下。

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

  一、新建代码库

  1. # 在当前目录新建一个 Git 代码库
  2. $ git init
  3.  
  4. # 新建一个目录,将其初始化为 Git 代码库
  5. $ git init [project-name]
  6.  
  7. # 下载一个项目和它的整个代码历史
  8. $ git clone [url]

  二、配置

  Git 的设置文件为.gitconfig,它可以在用户主目录下(全局配置),也可以在项目目录下(项目配置)。

  1. # 显示当前的 Git 配置
  2. $ git config --list
  3.  
  4. # 编辑 Git 配置文件
  5. $ git config -e [--global]
  6.  
  7. # 设置提交代码时的用户信息
  8. $ git config [--global] user.name "[name]"
  9. $ git config [--global] user.email "[email address]"

  三、增加/删除文件

  1. # 添加指定文件到暂存区
  2. $ git add [file1] [file2] ...
  3.  
  4. # 添加指定目录到暂存区,包括子目录
  5. $ git add [dir]
  6.  
  7. # 添加当前目录的所有文件到暂存区
  8. $ git add .
  9.  
  10. # 删除工作区文件,并且将这次删除放入暂存区
  11. $ git rm [file1] [file2] ...
  12.  
  13. # 停止追踪指定文件,但该文件会保留在工作区
  14. $ git rm --cached [file]
  15.  
  16. # 改名文件,并且将这个改名放入暂存区
  17. $ git mv [file-original] [file-renamed]

  四、代码提交

  1. # 提交暂存区到仓库区
  2. $ git commit -m [message]
  3.  
  4. # 提交暂存区的指定文件到仓库区
  5. $ git commit [file1] [file2] ... -m [message]
  6.  
  7. # 提交工作区自上次 commit 之后的变化,直接到仓库区
  8. $ git commit -a
  9.  
  10. # 提交时显示所有 diff 信息
  11. $ git commit -v
  12.  
  13. # 使用一次新的 commit,替代上一次提交
  14. # 如果代码没有任何新变化,则用来改写上一次 commit 的提交信息
  15. $ git commit --amend -m [message]
  16.  
  17. # 重做上一次 commit,并包括指定文件的新变化
  18. $ git commit --amend ...

  五、分支

  1. # 列出所有本地分支
  2. $ git branch
  3.  
  4. # 列出所有远程分支
  5. $ git branch -r
  6.  
  7. # 列出所有本地分支和远程分支
  8. $ git branch -a
  9.  
  10. # 新建一个分支,但依然停留在当前分支
  11. $ git branch [branch-name]
  12.  
  13. # 新建一个分支,并切换到该分支
  14. $ git checkout -b [branch]
  15.  
  16. # 新建一个分支,指向指定 commit
  17. $ git branch [branch] [commit]
  18.  
  19. # 新建一个分支,与指定的远程分支建立追踪关系
  20. $ git branch --track [branch] [remote-branch]
  21.  
  22. # 切换到指定分支,并更新工作区
  23. $ git checkout [branch-name]
  24.  
  25. # 建立追踪关系,在现有分支与指定的远程分支之间
  26. $ git branch --set-upstream [branch] [remote-branch]
  27.  
  28. # 合并指定分支到当前分支
  29. $ git merge [branch]
  30.  
  31. # 选择一个 commit,合并进当前分支
  32. $ git cherry-pick [commit]
  33.  
  34. # 删除分支
  35. $ git branch -d [branch-name]
  36.  
  37. # 删除远程分支
  38. $ git push origin --delete
  39. $ git branch -dr

  六、标签

  1. # 列出所有 tag
  2. $ git tag
  3.  
  4. # 新建一个 tag 在当前 commit
  5. $ git tag [tag]
  6.  
  7. # 新建一个 tag 在指定 commit
  8. $ git tag [tag] [commit]
  9.  
  10. # 查看 tag 信息
  11. $ git show [tag]
  12.  
  13. # 提交指定 tag
  14. $ git push [remote] [tag]
  15.  
  16. # 提交所有 tag
  17. $ git push [remote] --tags
  18.  
  19. # 新建一个分支,指向某个 tag
  20. $ git checkout -b [branch] [tag]

  七、查看信息

  1. # 显示有变更的文件
  2. $ git status
  3.  
  4. # 显示当前分支的版本历史
  5. $ git log
  6.  
  7. # 显示 commit 历史,以及每次 commit 发生变更的文件
  8. $ git log --stat
  9.  
  10. # 显示某个文件的版本历史,包括文件改名
  11. $ git log --follow [file]
  12. $ git whatchanged [file]
  13.  
  14. # 显示指定文件相关的每一次 diff
  15. $ git log -p [file]
  16.  
  17. # 显示指定文件是什么人在什么时间修改过
  18. $ git blame [file]
  19.  
  20. # 显示暂存区和工作区的差异
  21. $ git diff
  22.  
  23. # 显示暂存区和上一个 commit 的差异
  24. $ git diff --cached []
  25.  
  26. # 显示工作区与当前分支最新 commit 之间的差异
  27. $ git diff HEAD
  28.  
  29. # 显示两次提交之间的差异
  30. $ git diff [first-branch]...[second-branch]
  31.  
  32. # 显示某次提交的元数据和内容变化
  33. $ git show [commit]
  34.  
  35. # 显示某次提交发生变化的文件
  36. $ git show --name-only [commit]
  37.  
  38. # 显示某次提交时,某个文件的内容
  39. $ git show [commit]:[filename]
  40.  
  41. # 显示当前分支的最近几次提交
  42. $ git reflog

  八、远程同步

  1. # 下载远程仓库的所有变动
  2. $ git fetch [remote]
  3.  
  4. # 显示所有远程仓库
  5. $ git remote -v
  6.  
  7. # 显示某个远程仓库的信息
  8. $ git remote show [remote]
  9.  
  10. # 增加一个新的远程仓库,并命名
  11. $ git remote add [shortname] [url]
  12.  
  13. # 取回远程仓库的变化,并与本地分支合并
  14. $ git pull [remote] [branch]
  15.  
  16. # 上传本地指定分支到远程仓库
  17. $ git push [remote] [branch]
  18.  
  19. # 强行推送当前分支到远程仓库,即使有冲突
  20. $ git push [remote] --force
  21.  
  22. # 推送所有分支到远程仓库
  23. $ git push [remote] --all

  九、撤销

  1. # 恢复暂存区的指定文件到工作区
  2. $ git checkout [file]
  3.  
  4. # 恢复某个 commit 的指定文件到工作区
  5. $ git checkout [commit] [file]
  6.  
  7. # 恢复上一个 commit 的所有文件到工作区
  8. $ git checkout .
  9.  
  10. # 重置暂存区的指定文件,与上一次 commit 保持一致,但工作区不变
  11. $ git reset [file]
  12.  
  13. # 重置暂存区与工作区,与上一次 commit 保持一致
  14. $ git reset --hard
  15.  
  16. # 重置当前分支的指针为指定 commit,同时重置暂存区,但工作区不变
  17. $ git reset [commit]
  18.  
  19. # 重置当前分支的 HEAD 为指定 commit,同时重置暂存区和工作区,与指定 commit 一致
  20. $ git reset --hard [commit]
  21.  
  22. # 重置当前 HEAD 为指定 commit,但保持暂存区和工作区不变
  23. $ git reset --keep [commit]
  24.  
  25. # 新建一个 commit,用来撤销指定 commit
  26. # 后者的所有变化都将被前者抵消,并且应用到当前分支
  27. $ git revert [commit]

  十、其他

  1. # 生成一个可供发布的压缩包
  2. $ git archive

  完http://news.cnblogs.com/n/534449/

常用Git命令清单(转)的更多相关文章

  1. 常用 Git 命令清单

    我每天使用 Git ,但是很多命令记不住. 一般来说,日常使用只要记住下图6个命令,就可以了.但是熟练使用,恐怕要记住60-100个命令. 下面是我整理的常用 Git 命令清单.几个专用名词的译名如下 ...

  2. 常用 Git 命令清单 转

    我每天使用 Git ,但是很多命令记不住. 一般来说,日常使用只要记住下图6个命令,就可以了.但是熟练使用,恐怕要记住60-100个命令. 下面是我整理的常用 Git 命令清单.几个专用名词的译名如下 ...

  3. 常用 Git 命令清单(摘录)

    来源:阮一峰的网络日志 网址:http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html 我每天使用 Git ,但是很多命令记不住. 一般来 ...

  4. [转]常用 Git 命令清单

    作者: 阮一峰 我每天使用 Git ,但是很多命令记不住. 一般来说,日常使用只要记住下图6个命令,就可以了.但是熟练使用,恐怕要记住60-100个命令. 下面是我整理的常用 Git 命令清单.几个专 ...

  5. 常用 Git 命令清单

    http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html 我每天使用 Git ,但是很多命令记不住. 一般来说,日常使用只要记住下图6个命 ...

  6. 常用Git命令清单。

    上期传送门:[清单]7个管理和优化网站资源的工具 下面是我整理的常用 Git 命令清单.几个专用名词的译名如下. Workspace:工作区 Index / Stage:暂存区 Repository: ...

  7. 常用 Git 命令清单【转】

    转自:http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html 作者: 阮一峰 日期: 2015年12月 9日 我每天使用 Git ,但是 ...

  8. 170726、常用 Git 命令清单

    ,下面是我整理的常用 Git 命令清单.几个专用名词的译名如下: Workspace:工作区 Index / Stage:暂存区 Repository:仓库区(或本地仓库) Remote:远程仓库 一 ...

  9. Git(二):常用 Git 命令清单

    转: http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html 我每天使用 Git ,但是很多命令记不住. 一般来说,日常使用只要记住下图 ...

随机推荐

  1. ldconfig命令

    ldconfig是一个动态链接库管理命令 为了让动态链接库为系统所共享,还需运行动态链接库的管理命令--ldconfigldconfig 命令的用途,主要是在默认搜寻目录(/lib和/usr/lib) ...

  2. Keras 2.0版本运行

    Keras 2.0版本运行demo出错: d:\program\python3\lib\site-packages\ipykernel_launcher.py:8: UserWarning: Upda ...

  3. ReferenceError: weakly-referenced object no longer exists Python kafka

    Python存入kafka报错,ReferenceError: weakly-referenced object no longer exists. Exception in thread 14: p ...

  4. 如何上传代码到github?

    如何上传代码到github? 首先你需要一个github账号,所有还没有的话先去注册吧! https://github.com/ 我们使用git需要先安装git工具,这里给出下载地址,下载后一路直接安 ...

  5. jeecg中datagrid中获取选定行的字段值

    datagrid代码如下: <t:datagrid name="orderMainList" checkbox="true" pagination=&qu ...

  6. unity, ContentSizeFitter立即生效

    ugui Text上添加了ContentSizeFitter组件后,如果在代码里对Text.text重新赋值,文本框并不会马上改变大小,而是会延迟到下一帧. 如果想立刻生效,需要调用 Text.Get ...

  7. elasticsearch 性能监控基础

    一.Elasticsearch 是什么 Elasticsearch是一款用Java编写的开源分布式文档存储和搜索引擎,可以用于near real-time存储和数据检索. 1.Elasticsearc ...

  8. CentOS 7 安装以及配置

    http://blog.csdn.net/qzc295919009/article/details/42708653

  9. matlab M文件分析工具使用(Code Analyzer and Profiler)

    Code Analyzer and Profiler Matlab中,对写在m文件(.m文件)里的代码有分析的工具,可以进行优化,这里做一个简单的介绍. Code Analyzer Code Anal ...

  10. zsh与oh-my-zsh

    在开始今天的 MacTalk 之前,先问两个问题吧: 1.相对于其他系统,Mac 的主要优势是什么?2.你们平时用哪种 Shell?…… 第一个童靴可以坐下了,Mac 的最大优势是 GUI 和命令行的 ...