Skip to content

Latest commit

 

History

History
899 lines (784 loc) · 19 KB

git.md

File metadata and controls

899 lines (784 loc) · 19 KB

Git Cheat Sheet

查看卡片式效果

目录

初始化仓库

配置

忽略文件

添加删除移动文件

工作区状态

显示更改

列出文件信息

储藏与恢复

恢复工作区

回退版本

分支

切换分支

合并分支

远程仓库

推送与拉取

提交

日志

标签

追责(甩锅)

确认坏的提交

git 对象

查找

打包

初始化仓库

初始化仓库

``` sh git init ```

初始化裸仓库

``` sh git init --bare ```

克隆仓库

``` sh git clone ```

配置

编辑配置文件

``` sh git config [--global] -e ```

列出配置信息

``` sh git config -l ```

获取相应的配置

``` sh git config --get core.editor ```

配置用户邮箱

``` sh git config --global user.email ```

配置用户名

``` sh git config --global user.name ```

输出彩色信息

``` sh git config color.ui true ```

设置文件名大小写敏感

``` sh git config core.ignoreCase false ```

设置推送策略为 simple

``` sh git config push.default simple ```

设置 git 的编辑器是 vim

``` sh git config --global core.editor vim ```

设置命令别名

``` sh git config --global alias.co checkout ```

忽略文件

添加本项目的忽略文件

``` sh vim .gitignore ```

添加本项目的忽略文件并不把此文件纳入版本管理

``` sh vim .git/info/exclude ```

设置全局忽略文件

``` sh git config --global core.excludesfile ~/.gitignore ```

对已加入版本管理的文件不做更改检查

``` sh git update-index --assume-unchanged ```

对已加入版本管理的文件做更改检查

``` sh git update-index --no-assume-unchanged ```

添加删除移动文件

添加所有文件到暂存区,包括未追踪文件

``` sh git add -A ```

更新暂存区文件

``` sh git add -u ```

交互式添加文件到暂存区

``` sh git add -p ```

工作区与暂存区删除文件

``` sh git rm ```

仅暂存区删除文件

``` sh git rm --cached ```

重命名暂存区文件

``` sh git mv ```

工作区状态

查看工作区的信息

``` sh git status ```

查看工作区信息并显示分支及追踪信息

``` sh git status -sb ```

并查看忽略文件的信息

``` sh git status --ignored ```

列出忽略文件

``` sh git check-ignore * ```

显示更改

显示工作区与暂存区的不同

``` sh git diff ```

显示暂存区与本地仓库的不同

``` sh git diff --cached ```

显示工作区,暂存区与本地仓库的不同

``` sh git diff HEAD ```

仅显示改变的文件

``` sh git diff --name-only ```

比较两次提交的差异

``` sh git diff ```

显示某次 commit 所做的更改

``` sh git show ```

列出文件信息

列出暂存区文件

``` sh git ls-files ```

列出忽略文件与未追踪文件

``` sh git ls-files -o ```

子目录中显示所在位置

``` sh git ls-files --full-name ```

储藏与恢复

储藏(stash)工作区相对暂存区更改的文件

``` sh git stash ```

储藏文件并添加描述信息

``` sh git stash save ```

恢复最后一次储藏的文件

``` sh git stash apply ```

恢复最后一次储藏的文件并删除此次储存记录

``` sh git stash pop ```

查看储藏列表

``` sh git stash list ```

恢复工作区

重置工作区某文件

``` sh git checkout -- ```

重置工作区

``` sh git checkout . ```

列出将要清除的未追踪文件

``` sh git clean -n ```

清除未追踪文件

``` sh git clean -f ```

清除忽略文件

``` sh git clean -Xf ```

清除未追踪目录及文件

``` sh git clean -df ```

回退版本

重置暂存区

``` sh git reset ```

重置工作区和暂存区

``` sh git reset --hard ```

恢复本分支到某次提交,重置工作区与暂存区

``` sh git reset --hard ```

恢复本分支到某次提交

``` sh git reset --soft ```

恢复本分支到某次提交,重置暂存区

``` sh git reset --mixed ```

反向恢复一个提交并生成新的提交

``` sh git revert ```

分支

列出本地分支

``` sh git branch ```

列出本地分支与追踪关系

``` sh git branch -vv ```

列出远程分支

``` sh git branch -r ```

列出所有分支

``` sh git branch -a ```

建立分支不切换工作区

``` sh git branch ```

删除已被合并的分支

``` sh git branch -d ```

强制删除未被合并的分支

``` sh git branch -D ```

更改分支名字

``` sh git branch -m ```

设置追踪分支

``` sh git branch -u ```

切换分支

切换分支

``` sh git checkout ```

建立分支并切换工作区

``` sh git checkout -b ```

切换到最近一次分支

``` sh git checkout - ```

建立无任何提交历史的分支

``` sh git checkout --orphan ```

合并分支

合并 develop 分支到本分支

``` sh git merge develop ```

强制合并分支后生成 merge commit

``` sh git merge -no-ff develop ```

合并最近切换分支

``` sh git merge - ```

变基合并 develop 分支

``` sh git rebase develop ```

变基进入交互式界面

``` sh git rebase -i ```

远程仓库

添加远程仓库并命名为 origin

``` sh git remote add origin ```

修改远程仓库的地址

``` sh git remote set-url origin ```

列出所有的远程仓库

``` sh git remote -v ```

列出远程仓库 origin 的详细信息

``` sh git remote show origin ```

推送与拉取

git config push.default simple

``` sh 设置默认推送策略为 simple ```

推送 master 到远程仓库

``` sh git push origin master ```

推送到远程仓库并建立追踪关系

``` sh git push -u origin master ```

推送时忽略 pre-push hook

``` sh git push -n ```

从远程仓库拉取文件

``` sh git pull origin master ```

设置 rebase 模式拉取代码

``` sh git pull --rebase origin master ```

提交

提交

``` sh git commit -m ```

追加提交重置提交信息

``` sh git commit --amend -m ```

重置作者

``` sh git commit --amend --author= ```

允许空提交

``` sh git commit --allow-empty ```

提交时跳过 pre-commit hook

``` sh git commit -n ```

日志

显示提交日志

``` sh git log ```

显示某文件的提交日志

``` sh git log -p ```

以图表形式显示提交日志

``` sh git log --graph --all --oneline --decorate ```

显示每次提交的对象信息

``` sh git log --pretty=raw ```

显示某个时间段的提交信息

``` sh git log --since '2 days ago' ```

显示指定作者的提交信息

``` sh git log --author= ```

根据提交信息中的关键字查找

``` sh git log --grep= ```

根据提交源码中的关键字查找

``` sh git log -S ```

列出二者特有的提交

``` sh git log master...develop ```

列出 branch 有而 branch2 没有的提交

``` sh git log branch2..branch ```

仅显示 merge commit

``` sh git log --merges ```

统计每个作者的提交情况

``` sh git shortlog ```

统计每个作者的提交个数

``` sh git shortlog -sn ```

标签

列出所有标签并显示标签信息

``` sh git tag -ln ```

添加一个标签

``` sh git tag -a v1.0.0 -m ```

在某个 commit 上添加一个标签

``` sh git tag v0.9.0 ```

删除一个标签

``` sh git tag -d v1.0.0 ```

查看某个标签信息

``` sh git show v1.0.0 ```

推送所有标签到远程仓库

``` sh git push --tags ```

使用最近的标签描述本次提交

``` sh git describe ```

追责(甩锅)

找到最后一次提交的作者

``` sh git blame ```

找到具体某一段的最后一次提交

``` sh git blame -L 10,18 ```

查找文件的修改历史及明细

``` sh git log -p ```

确认坏的提交

二分查找坏的提交

``` sh git bisect start
git checkout HEAD~20
git bisect good
git bisect bad
git bisect reset ```

git 对象

获取改摘要信息的类型

``` sh git cat-file -t ```

获取改摘要信息的内容

``` sh git cat-file -p ```

查找

在已追踪文件中查找关键字并指明行号

``` sh git grep -n hello ```

打包

打包

``` sh git archive -o arch.zip HEAD ```