git常用操作总结

544 阅读4分钟

下载

Mac环境

  1. 二进制安装 sourceforge.net/projects/gi…

cherry-pick

指定的提交(commit)应用于其他分支

$ git cherry-pick <commitHash>

git cherry-pick命令的参数,不一定是提交的哈希值,分支名也是可以的,表示转移该分支的最新提交。

$ git cherry-pick feature

Cherry pick 支持一次转移多个提交。

git cherry-pick <HashA> <HashB>

提交回滚

1. 场景一(已经git push)

// 回滚最新一次提交
git revert HEAD 
// 回滚上上一次提交
git revert HEAD^

2. 场景二(未 git add)

// 撤销所有修改
git checkout .

3. 场景三(已 git add)

// 撤销所有修改
git reset

4. 场景四(已经commit)

git reset --mixed xxxxxxxxx (默认) 重置为未add的状态

git reset --soft xxxxxxxxx 重置为add状态

git reset --hard xxxxxxxxx 重置为修改丢失的状态

想要reset必须指定某一次提交的上一次的log ID

git push origin xxx --force

暂存(stage)

  1. 执行 git stash, 默认是不带注释的,想要后面看的更清楚该 stash 是存储的什么,可以如下操作: 执行 git stash save "commend"
  2. 查看刚才保存的工作进度 git stash list
  3. 这时候在看分支已经是干净无修改的(改动都有暂存到 stash)
  4. 现在就可以正常切换到目标分支,进行相应操作
  5. 其他分支处理完成,再切回来使用刚才的 stash, 还是先查看 暂缓列表
  6. 选择使用暂缓 git stash apply n 注:n 是序号,如下图红色箭头指示

对比

  1. git比较本地仓库和远程仓库的差异。

本地与远程的差集 :(显示远程有而本地没有的commit信息)

git log master..origin/master

统计文件的改动

# git diff <local branch> <remote>/<remote branch>
git diff --stat master origin/master
  1. git 比较本地之间的差异
git diff不加参数即默认比较工作区与暂存区

git diff --cached [<path>...]比较暂存区与最新本地版本库(本地库中最近一次commit的内容)

git diff HEAD [<path>...]比较工作区与最新本地版本库。如果HEAD指向的是master分支,那么HEAD还可以换成master

git diff commit-id [<path>...]比较工作区与指定commit-id的差异  

git diff --cached [<commit-id>] [<path>...]比较暂存区与指定commit-id的差异

git diff [<commit-id>] [<commit-id>]比较两个commit-id之间的差异

分支合并

git merge 分支

取消分支合并
git merge --abort

git tag(打标签)

// 在commit 之后,push之前,去添加tag

1. 添加tag
git tag -a v1.0.0 -m "commit version 1.0.0"

2. 删除tag
git tag -d v1.0.0

3. 查看tag
git tag

4. 覆盖、替换tag
git tag -f v1.0.0

5. 轻量级tag(就是去掉前端的-a -s等)
git tag v1.0.0
如果现在对这个标签使用’git show’命令,不会看到像上面那种标签显示的那么多内容,仅仅显示这次提交的有关信息。

别名

$ git config --global alias.co checkout
$ git config --global alias.ci commit
$ git config --global alias.br branch

配置一个git last,让其显示最后一次提交信息:

$ git config --global alias.last 'log -1'

git缩写

以下为zsh && oh-my-zsh给出的Git简写方式,安装oh-my-zsh的同学可以直接用,未安装的同学也可把这些命令配置到自己的~/.bash_profile使用。

alias g='git'
alias ga='git add'
alias gaa='git add --all'
alias gapa='git add --patch'
alias gau='git add --update'
alias gav='git add --verbose'
alias gap='git apply'

alias gb='git branch'
alias gba='git branch -a'
alias gbd='git branch -d'
alias gbda='git branch --no-color --merged | command grep -vE "^(\+|\*|\s*(master|develop|dev)\s*$)" | command xargs -n 1 git branch -d'
alias gbD='git branch -D'
alias gbl='git blame -b -w'
alias gbnm='git branch --no-merged'
alias gbr='git branch --remote'
alias gbs='git bisect'
alias gbsb='git bisect bad'
alias gbsg='git bisect good'
alias gbsr='git bisect reset'
alias gbss='git bisect start'

alias gc='git commit -v'
alias gc!='git commit -v --amend'
alias gcn!='git commit -v --no-edit --amend'
alias gca='git commit -v -a'
alias gca!='git commit -v -a --amend'
alias gcan!='git commit -v -a --no-edit --amend'
alias gcans!='git commit -v -a -s --no-edit --amend'
alias gcam='git commit -a -m'
alias gcsm='git commit -s -m'
alias gcb='git checkout -b'
alias gcf='git config --list'
alias gcl='git clone --recurse-submodules'
alias gclean='git clean -id'
alias gpristine='git reset --hard && git clean -dfx'
alias gcm='git checkout master'
alias gcd='git checkout develop'
alias gcmsg='git commit -m'
alias gco='git checkout'
alias gcount='git shortlog -sn'
alias gcp='git cherry-pick'
alias gcpa='git cherry-pick --abort'
alias gcpc='git cherry-pick --continue'
alias gcs='git commit -S'

alias gd='git diff'
alias gdca='git diff --cached'
alias gdcw='git diff --cached --word-diff'
alias gdct='git describe --tags $(git rev-list --tags --max-count=1)'
alias gds='git diff --staged'
alias gdt='git diff-tree --no-commit-id --name-only -r'
alias gdw='git diff --word-diff'
alias gf='git fetch'
alias gfa='git fetch --all --prune'
alias gfo='git fetch origin'
alias gfg='git ls-files | grep'
alias gg='git gui citool'
alias gga='git gui citool --amend'

alias ggpull='git pull origin "$(git_current_branch)"'
alias ggpush='git push origin "$(git_current_branch)"'

alias ggsup='git branch --set-upstream-to=origin/$(git_current_branch)'
alias gpsup='git push --set-upstream origin $(git_current_branch)'

alias ghh='git help'

alias gignore='git update-index --assume-unchanged'
alias gignored='git ls-files -v | grep "^[[:lower:]]"'
alias git-svn-dcommit-push='git svn dcommit && git push github master:svntrunk'

alias gk='\gitk --all --branches'
alias gke='\gitk --all $(git log -g --pretty=%h)'

alias gl='git pull'
alias glg='git log --stat'
alias glgp='git log --stat -p'
alias glgg='git log --graph'
alias glgga='git log --graph --decorate --all'
alias glgm='git log --graph --max-count=10'
alias glo='git log --oneline --decorate'
alias glol="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset'"
alias glols="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --stat"
alias glod="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset'"
alias glods="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%ad) %C(bold blue)<%an>%Creset' --date=short"
alias glola="git log --graph --pretty='%Cred%h%Creset -%C(auto)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --all"
alias glog='git log --oneline --decorate --graph'
alias gloga='git log --oneline --decorate --graph --all'
alias glp="_git_log_prettily"

alias gm='git merge'
alias gmom='git merge origin/master'
alias gmt='git mergetool --no-prompt'
alias gmtvim='git mergetool --no-prompt --tool=vimdiff'
alias gmum='git merge upstream/master'
alias gma='git merge --abort'

alias gp='git push'
alias gpd='git push --dry-run'
alias gpf='git push --force-with-lease'
alias gpf!='git push --force'
alias gpoat='git push origin --all && git push origin --tags'
alias gpu='git push upstream'
alias gpv='git push -v'

alias gr='git remote'
alias gra='git remote add'
alias grb='git rebase'
alias grba='git rebase --abort'
alias grbc='git rebase --continue'
alias grbd='git rebase develop'
alias grbi='git rebase -i'
alias grbm='git rebase master'
alias grbs='git rebase --skip'
alias grev='git revert'
alias grh='git reset'
alias grhh='git reset --hard'
alias groh='git reset origin/$(git_current_branch) --hard'
alias grm='git rm'
alias grmc='git rm --cached'
alias grmv='git remote rename'
alias grrm='git remote remove'
alias grs='git restore'
alias grset='git remote set-url'
alias grss='git restore --source'
alias grt='cd "$(git rev-parse --show-toplevel || echo .)"'
alias gru='git reset --'
alias grup='git remote update'
alias grv='git remote -v'

alias gsb='git status -sb'
alias gsd='git svn dcommit'
alias gsh='git show'
alias gsi='git submodule init'
alias gsps='git show --pretty=short --show-signature'
alias gsr='git svn rebase'
alias gss='git status -s'
alias gst='git status'

alias gstaa='git stash apply'
alias gstc='git stash clear'
alias gstd='git stash drop'
alias gstl='git stash list'
alias gstp='git stash pop'
alias gsts='git stash show --text'
alias gstall='git stash --all'
alias gsu='git submodule update'
alias gsw='git switch'
alias gswc='git switch -c'

alias gts='git tag -s'
alias gtv='git tag | sort -V'
alias gtl='gtl(){ git tag --sort=-v:refname -n -l "${1}*" }; noglob gtl'

alias gunignore='git update-index --no-assume-unchanged'
alias gunwip='git log -n 1 | grep -q -c "\-\-wip\-\-" && git reset HEAD~1'
alias gup='git pull --rebase'
alias gupv='git pull --rebase -v'
alias gupa='git pull --rebase --autostash'
alias gupav='git pull --rebase --autostash -v'
alias glum='git pull upstream master'

alias gwch='git whatchanged -p --abbrev-commit --pretty=medium'
alias gwip='git add -A; git rm $(git ls-files --deleted) 2> /dev/null; git commit --no-verify --no-gpg-sign

客户端可视化工具

sourceTree

下载地址

www.sourcetreeapp.com/

F&Q

  1. Mac中出现git auth failed,首先检查你是否有仓库权限,然后如果有的话可就是你更改了用户名和密码,在mac的钥匙串访问中,选择密码搜索sourceTree然后删除,这样再次提交的时候就会让你重新填写用户名和密码

Tower