最全Git命令,掌握命令行操作。

  • git 中的路径都要用网络路径,正斜杠”/”.
  • 暂存区:保存add命令添加的修改
  • git init 初始化
  • git add ‘file’ 将文件添加到仓库(git add . 添加所有文件)
  • git status 查看文件状态(基于版本库)
  • git commit -m “msg” 提交更改(Insert 进入修改模式,Esc进入命令模式 :wq保存并退出 :q!不保存退出)
  • git log 查看log(q 退出log)
  • git reset –hard HEAD^ 回退到之前版本(^ 上个版本,^^上上个版本,~100前一百个版本)
  • git reflog 查看过去的版本信息(版本号)
    • HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令git reset –hard commit_id。
    • 穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
    • 要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。
  • git diff HEAD – ‘file’ 比较文件在版本和工作区之间的差异。
  • cat ‘file’ 查看文件内容
  • 撤销修改
    • git checkout – ‘file’ 将工作区和暂存区进行比较,丢弃工作区的修改,回到add到暂存区后的版本;
    • git reset –soft HEAD ‘file’ 将暂存区和HEAD版本比较,丢弃暂存区的修改;
    • 以上两个命令结合可以将工作区回退到HEAD版本;
  • 分支
    • git branch -a 查看分支(包括远程分支)
    • git branch -r 查看远程分支
    • git branch ‘branchName’ 创建分支
    • git checkout ‘branchName’ 切换分支
    • git checkout -b ‘branchName’ 创建并切换分支
    • git checkout -b ‘localBranchName’ ‘remoteBranchName’ 将远程分支checkout到本地的新建分支下
    • git merge ‘branchName’ 合并分支到当前分支
    • git merge –no-ff ‘branchName’ 用普通模式合并分支,这样就能看到分支记录
    • git branch -d ‘branchName’ 删除分支(如果该分支没有被合并,只能用下一条命令执行删除
    • git branch -D ‘branchName’ 强行删除分支
  • 解决冲突
    • git merge 的时候如果有冲突,会用”””’,=======,”””’标记出不同分支的内容,解决冲突后再add并commit就可以了。
    • git log –graph –pretty=oneline 查看分支图
  • 储存现场
    • git stash 当你开发到一半无法提交时,需要去解决一个紧急bug,可以用该命令将当前工作区的内容(被git管理的)存储在stash中,解决了bug后,再恢复现场.
    • git stash list 查看stash列表
    • git stash apply [‘stashName’] 将工作区回到存储的现场
    • git stash drop [‘stashName’] 删除现场
    • git stash pop [‘stashName’] 将工作区回到现场并删除现场
    • git stash save [] 备注现场
    • git stash clear 清空stash列表
  • git pull ‘远程主机名’ ‘远程分支名’:’本地分支名’
  • 全局配置
    • git config –global user.email “[email protected]
    • git config –global user.name “Your Name”
  • 远程操作
    • git remote add [origin] [git address]:添加远程仓库,将本地仓库链接到git address对应的远程仓库,然后就可以push本地内容到git远程仓库了;
    • git remote -v 查看远程仓库信息
    • git pull origin ‘rBranchName’:’lBranchName’ 从远程仓库的分支下拉取代码到本地分支
    • pull操作相当于git fetch origin ‘rBranchName’ –’ git log -p ‘lBranchName’..origin/’rBranchName’ –’ git merge origin/’rBranchName’
    • git fetch origin ‘rBranchName’ 将远程仓库的分支代码拉取到本地,保存在.git文件夹中,但是不执行合并操作
    • git push origin ‘lBranchName’:’rBranchName’ 提交代码到远程仓库,本地分支在冒号前面.
    • 过时git branch –set-upstream [‘lBranchName’] origin/’rBranchName’
    • git branch –set-upstream-to=origin/’rBranch’ ‘lBranch’:将本地分支tracing远程分支,这样执行git push origin 操作的时候,就会默认将代码提交到指定的远程分支上,该命令只需执行一次.
    • git log –graph –pretty=oneline –abbrev-commit:查看分支图
    • git cherry-pick ‘commit-id’:将某次commit应用到该分支,可以跨分支。
    • git push origin :’rBranchName’:通过push一个空的本地分支到远程库的方式,删除远程分支
    • git push & git pull:在某个分支执行git push,只会push当前分支到远程库,如果要push其他分支,需要在push后加上分支信息;但是执行git pull,会将远程库中所有的分支信息都更新,不过只有当前分支会直接merge到本地代码上,对于其他分支,相当于执行了一次fetch

你可能感兴趣的:(原创)