Git基本使用命令
2022-04-19 本文已影响0人
程序记录日志
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