Git基本使用命令

Git配置

Git最小配置

  • 配置全局账户,该账户对所有Git仓库都有效
git config --global user.name '账户名称'
git config --global user.email 'Email地址'
  • 配置局部账户,该账户对当前Git仓库有效
git config --local user.name '账户名称'
git config --local user.email 'Email地址'

查看相关配置

  • 查看global类型的配置情况
git config --global --list
  • 查看某个仓库下的配置情况
git config --local --list

本地基本操作

基本操作

  • 查看变更情况
git status
  • 查看当前工作在那个分支
git branch -v
  • 切换到指定分支
git checkout 指定分支名称
  • 把当前目录及其子目录下所有变更都加入到暂存区
git add .
  • 把仓库内所有变更都加入到暂存区
git add -A
  • 把指定文件添加到暂存区
git add 文件1 文件2 ...
  • 创建commit,提交当前数据
git commit

比较差异

  • 比较某文件工作区暂存区的差异
git diff 某文件
  • 比较某文件暂存区和HEAD的差异
git diff --cache 某文件
  • 比较工作区和暂存区的所有差异
git diff
  • 比较暂存区和HEAD的所有差异
git diff --cache

暂存区与工作区之间回滚

  • 把工作区指定文件恢复成和暂存区一样
git checkout 文件1 文件2 ...
  • 把暂存区指定文件恢复和HEAD一样
git reset 文件1 文件2 ...
  • 把暂存区和工作区所有文件恢复成和HEAD一样
git reset --hard
  • difftool比较任意两个commit的差异
git difftool commit1 commit2

其他

  • 查看哪些文件没有被Git管控
git ls-files --others

临时任务处理

  • 把未处理完的变更先保存到stash
git stash
  • 临时任务处理完后,继续之前的工作
git stash pop			# 把之前任务弹出
或者
git stash apply			# 从栈顶把任务取出
  • 查看所有的stash
git stash list
  • 取回某次stash的变更
git stash pop stash @{数字}

修改分支历史

  • 修改最后一次commit
git add
git commit --amend
  • 修改中间的commit
git rebase -i (commit的id)
git add
git rebase --contiue

查看变更日志

  • 当前分支各个commit用一行显示
git log --online
  • 显示最近的n个commit
git log -n
  • 用图示显示所有分支历史
git log --online --graph --all
  • 查看涉及到某文件变更的所有commit
git log 某文件
  • 某文件各行最后修改对应的commit以及作者
git blame 某文件

分支和标签

创建新分支

  • 基于当前分支创建新分支
git branch 新分支
  • 基于指定分支创建新分支
git branch 新分支 已有分支
  • 基于某个commit创建分支
git branch 新分支 某个commit的id
  • 创建分支并且切换到该分支
git chechout -b 新分支

列出分支

  • 列出本地分支
git branch -v
  • 列出本地和远端分支
git branch -av
  • 列出远端所有分支
git branch -rv
  • 列出名称符号某样式的远端分支
git branch -rv -l '某样式'

删除分支

  • 安全删除本地某分支
git branch -d 要删除的分支
  • 强行删除本地分支
git branch -D 要删除的分支
  • 删除已合并到master分支的所有本地分支
git branch --merged master | grep -v '^\*\ | master ' | xargs -n 1 git branch -d
  • 删除远端origin已不存在的所有本地分支
git remote prune origin

打标签

  • commit打上标签
git tag 标签名 (commit的id)

两分支之间的集合

  • A分支合入到当前分支,且为merge创建commit
git merge A分支
  • A分支合入到B分支,且为Merge创建commit
git merge A分支 B分支
  • 当前分支基于B分支做rebase,以便把B分支合入到当前分支
git rebase B分支
  • A分支基于B分支做rebase,以便把B分支合入到A分支
git rebase B分支 A分支
  • mergetool解决冲突
git mergetool

远端交互

  • 列出所有 remote
git remote -v
  • 增加 remote
git remote add url地址
  • 删除 remote
git remote remove (remote的名称)
  • 改变 remote的 name
git remote rename 旧名称 新名称
  • 把远端所有分支和标签的变更都拉到本地
git fetch remote
  • 把远端分支的变更拉到本地,且 merge到本地分支
git pull remote名称 分支名
  • 本地分支push到远端
git push remote名称 分支名
  • 删除远端分支
git push remote --delete 远端分支名
或者
git push remote:远端分支名
  • 远端提交指定标签
git push remote 标签名
  • 远端提交所有标签
git push remote --tags
posted @ 2022-04-19 22:15  下月初相见  阅读(37)  评论(0编辑  收藏  举报