Git Cheat Sheet

本文来自我fork并翻译的repo Git Cheat Sheet

也会在Gevin的博客上做不同步的更新

索引

  • 创建
  • 本地修改
  • 提交历史
  • 分支与标签
  • 更新与发布
  • 合并与重置
  • 撤销

创建

复制一个已创建的仓库:

$ git clone ssh://[email protected]/repo.git

创建一个新的本地仓库:

$ git init

本地修改

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

$ git status

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

$ git diff

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

$ git add .

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

$ git add -p 

提交本地的所有修改:

$ git commit -a

提交之前已标记的修改:

$ git commit

附加消息提交:

$ git commit -m 'message here'

修改上次提交
Don't amend published commits!

$ git commit --amend

提交历史

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

$ git log

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

$ git log --oneline

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

$ git log --author="username"

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

$ git log -p 

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

$ git blame 

分支与标签

列出所有的分支:

$ git branch

切换分支:

$ git checkout 

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

$ git branch 

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

$ git branch --track  

删除本地分支:

$ git branch -d 

给当前版本打标签:

$ git tag 

更新与发布

列出对当前远程端的操作:

$ git remote -v

显示远程端的信息:

$ git remote show 

添加新的远程端:

$ git remote add  

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

$ git fetch 

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

$ git remote pull  

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

$ git pull origin master

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

$ git push remote  

删除远程端分支:

$ git push  : (since Git v1.5.0)
or
git push  --delete  (since Git v1.7.0)

发布标签:

$ git push --tags

合并与重置

将分支合并到当前HEAD中:

$ git merge 

将当前HEAD版本重置到分支中:

Don't rebase published commit!

$ git rebase 

退出重置:

$ git rebase --abort

解决冲突后继续重置:

$ git rebase --continue

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

$ git mergetool

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

$ git add 
$ git rm 

撤销

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

$ git reset --hard HEAD

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

$ git reset HEAD

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

$ git checkout HEAD 

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

$ git revert 

将HEAD重置到上一次提交的版本,并放弃之后的所有修改:

$ git reset --hard 

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

$ git reset 

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

$ git reset --keep 

你可能感兴趣的:(Git Cheat Sheet)