shfshanyue / Cheat Sheets
Stars: ✭ 64
Labels
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 ``` 设置文件名大小写敏感
``` sh git config push.default simple ``` 设置推送策略为 simple
``` sh git config --global core.editor vim ``` 设置 git 的编辑器是 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 ``` 比较两次提交的差异
``` sh git show ``` 显示某次 commit 所做的更改
列出文件信息
``` sh git ls-files ``` 列出暂存区文件
``` sh git ls-files -o ``` 列出忽略文件与未追踪文件
``` sh git ls-files --full-name ``` 子目录中显示所在位置
储藏与恢复
``` sh git stash ``` 储藏(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 ``` 建立无任何提交历史的分支
合并分支
``` sh git merge develop ``` 合并 develop 分支到本分支
``` sh git merge -no-ff develop ``` 强制合并分支后生成 merge commit
``` sh git merge - ``` 合并最近切换分支
``` sh git rebase develop ``` 变基合并 develop 分支
``` sh git rebase -i ``` 变基进入交互式界面
远程仓库
``` sh git remote add origin ``` 添加远程仓库并命名为 origin
``` sh git remote set-url origin ``` 修改远程仓库的地址
``` sh git remote -v ``` 列出所有的远程仓库
``` sh git remote show origin ``` 列出远程仓库 origin 的详细信息
推送与拉取
``` sh 设置默认推送策略为 simple ``` git config push.default simple
``` sh git push origin master ``` 推送 master 到远程仓库
``` sh git push -u origin master ``` 推送到远程仓库并建立追踪关系
``` sh git push -n ``` 推送时忽略 pre-push hook
``` sh git pull origin master ``` 从远程仓库拉取文件
``` sh git pull --rebase origin master ``` 设置 rebase 模式拉取代码
提交
``` sh git commit -m ``` 提交
``` sh git commit --amend -m ``` 追加提交重置提交信息
``` sh git commit --amend --author= ``` 重置作者
``` sh git commit --allow-empty ``` 允许空提交
``` sh git commit -n ``` 提交时跳过 pre-commit hook
日志
``` 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 ``` 列出二者特有的提交
``` sh git log branch2..branch ``` 列出 branch 有而 branch2 没有的提交
``` sh git log --merges ``` 仅显示 merge commit
``` sh git shortlog ``` 统计每个作者的提交情况
``` sh git shortlog -sn ``` 统计每个作者的提交个数
标签
``` sh git tag -ln ``` 列出所有标签并显示标签信息
``` sh git tag -a v1.0.0 -m ``` 添加一个标签
``` sh git tag v0.9.0 ``` 在某个 commit 上添加一个标签
``` 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 ``` 打包
Note that the project description data, including the texts, logos, images, and/or trademarks,
for each open source project belongs to its rightful owner.
If you wish to add or remove any projects, please contact us at [email protected].