git经常使用命令备忘

一.分支相关git

1.基本命令bash

# 列出全部本地分支
$ git branch
 
# 列出全部远程分支
$ git branch -r
 
# 列出全部本地分支和远程分支
$ git branch -a
 
# 新建一个分支,但依然停留在当前分支
$ git branch [branch-name]
 
# 新建一个分支,并切换到该分支
$ git checkout -b [branch]
 
# 新建一个分支,与指定的远程分支创建追踪关系
$ git branch --track [branch] [remote-branch]
 
# 切换到指定分支,并更新工做区
$ git checkout [branch-name]
 
# 切换到上一个分支
$ git checkout -
 
# 创建追踪关系,在现有分支与指定的远程分支之间
$ git branch --set-upstream [branch] [remote-branch]
 
# 合并指定分支到当前分支
$ git merge [branch]
# 删除分支
$ git branch -d [branch-name]
 
# 删除远程分支
$ git push origin --delete [branch-name]
$ git branch -dr [remote/branch]
 
#拉取全部分支代码
$ git fetch
 
#提交分支代码
$ git push <远程主机名> <本地分支名>:<远程分支名>
【分支推送顺序的写法是<来源地>:<目的地>,因此git pull是<远程分支>:<本地分支>,而git push是<本地分支>:<远程分支>。】
 
#暂存区
 

$git stash save "name"app

$git stash listfetch

$git stash apply stash@{3}xml


 

2、各类状况处理
#.放弃某个分支还没提交的全部修改
$ git checkout .
 
#假如你merge的时候产生了很大的冲突,想先放弃某次merge
$ git merge --abort 或
$ git reset HEAD 或
$ git checkout HEAD

 

 
#在非目的分支上作了修改,想切换回目的分支
 
1) 还未添加到暂存区/已添加到暂存区还未提交
1.1新建临时分支,git checkout -b new_branch,这样改动会被带到新分支。而后把非目的分支的修改用git checkout --恢复。
1.2先git stash,而后切换到目的分支,git checkout 【branch】,在目的分支git stash pop便可。这种方式最好理解,就是把改动先放到一个临时区域,让git先别管,到了正确的分支再拿出来。
 
2)已提交到本地仓库
这种状况就要有reset了,用git reset HEAD^撤销最近一次提交,若是有屡次提交的话,查找到对应提交id进行reset就行。git默认的是mixed模式,即撤销暂存区,保留工做区。这样你再切分支也还能把改动带过去。固然加--soft也能够,这样能保留暂存区和工做区。
 
3)已push到远程仓库
若是很不幸你已经把误修改给push了,你须要用到revert命令,先用git log查找到你误提交的commitId,而后git revert commitId,产生一次逆向提交,来对冲掉以前的。以后再push到远程就能够了。
 
 #git忽略而不提交文件
1)从未提交过的文件能够用.gitignore
这种最简单,直接把想忽略的文件加入gitignore中忽略提交便可
 
2)已经推送(push)过的文件,想从git远程库中删除,并在之后的提交中忽略,可是却还想在本地保留这个文件
$git rm --cached pages/index.wxml 
 
3)已经推送(push)过的文件,想在之后的提交时忽略此文件,即便本地已经修改过,并且不删除git远程库中相应文件
$git update-index --assume-unchanged pages/index.wxml 
若是要忽略一个目录,打开 git bash,cd到 目标目录下
$git update-index --assume-unchanged $(git ls-files | tr '\n' ' ') 
相关文章
相关标签/搜索