https://github.com/shfshanyue/cheat-sheets
https://github.com/shfshanyue/cheat-sheets
tip
Last synced: 2 months ago
JSON representation
- Host: GitHub
- URL: https://github.com/shfshanyue/cheat-sheets
- Owner: shfshanyue
- Created: 2017-02-18T01:37:28.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2022-12-06T16:27:54.000Z (over 3 years ago)
- Last Synced: 2025-01-26T15:13:58.050Z (over 1 year ago)
- Topics: tip
- Language: CSS
- Homepage: https://cheatsheeets.netlify.com/git
- Size: 209 KB
- Stars: 65
- Watchers: 7
- Forks: 20
- Open Issues: 7
-
Metadata Files:
- Readme: Readme.md
Awesome Lists containing this project
README
Git Cheat Sheet
查看卡片式效果
目录
初始化仓库
配置
忽略文件
添加删除移动文件
工作区状态
显示更改
列出文件信息
储藏与恢复
恢复工作区
回退版本
分支
切换分支
合并分支
远程仓库
推送与拉取
- git config push.default simple
- 推送 master 到远程仓库
- 推送到远程仓库并建立追踪关系
- 推送时忽略 pre-push hook
- 从远程仓库拉取文件
- 设置 rebase 模式拉取代码
提交
日志
- 显示提交日志
- 显示某文件的提交日志
- 以图表形式显示提交日志
- 显示每次提交的对象信息
- 显示某个时间段的提交信息
- 显示指定作者的提交信息
- 根据提交信息中的关键字查找
- 根据提交源码中的关键字查找
- 列出二者特有的提交
- 列出 branch 有而 branch2 没有的提交
- 仅显示 merge commit
- 统计每个作者的提交情况
- 统计每个作者的提交个数
标签
追责(甩锅)
确认坏的提交
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
```