git命令大总结(方便查询)

初始化仓库



初始化仓库

git init

初始化裸仓库

git init --bare

克隆仓库

git clone <git-repo>

配置



编辑配置文件

git config [--global] -e

列出配置信息

git config -l

获取相应的配置

git config --get core.editor

输出彩色信息

git config color.ui true

设置文件名大小写敏感

git config core.ignoreCase false

设置推送策略为 simple

git config push.default simple

设置 git 的编辑器是 vim

git config --global core.editor vim

设置命令别名

git config --global alias.co checkout

操作暂存区文件



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

git add -A

更新暂存区文件

git add -u

交互式添加文件到暂存区

git add -p

工作区与暂存区删除文件

git rm <file>

仅暂存区删除文件

git rm --cached <file>

重命名暂存区文件

git mv <file> <file1>

显示更改



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

git diff

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

git diff --cached

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

git diff HEAD

仅显示改变的文件

git diff --name-only

比较两次提交的差异

git diff <commit> <commit>

显示某次 commit 所做的更改

git show <commit>

分支



列出本地分支

git branch

列出本地分支与追踪关系

git branch -vv

列出远程分支

git branch -r

列出所有分支

git branch -a

建立分支不切换工作区

git branch <branch>

删除已被合并的分支

git branch -d <branch>

强制删除未被合并的分支

git branch -D <branch>

更改分支名字

git branch -m <newbranch>

设置追踪分支

git branch -u <upstream>

切换分支



切换分支

git checkout <branch>

建立分支并切换工作区

git checkout -b <branch>

切换到最近一次分支

git checkout -

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

git checkout --orphan <branch>

合并分支



合并 develop 分支到本分支

git merge develop

强制合并分支后生成 merge commit

git merge -no-ff develop

变基合并 develop 分支

git rebase develop

变基进入交互式界面

git rebase -i

重置工作区



重置工作区某文件

git checkout -- <file>

重置工作区

git checkout .

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

git clean -n

清除未追踪文件

git clean -f

清除忽略文件

git clean -Xf

清除未追踪目录及文件

git clean -df

重置暂存区与仓库



重置暂存区

git reset

重置工作区和暂存区

git reset --hard

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

git reset --hard <commit-ish>

恢复本分支到某次提交

git reset --soft <commit-ish>

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

git reset --mixed <commit-ish>

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

git revert <commit>

储藏与恢复



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

git stash

储藏文件并添加描述信息

git stash save <message>

恢复最后一次储藏的文件

git stash apply

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

git stash pop

查看储藏列表

git stash list

工作区状态



查看工作区的信息

git status

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

git status -sb

并查看忽略文件的信息

git status --ignored

列出忽略文件

git check-ignore *

远程仓库



添加远程仓库并命名为 origin

git remote add origin <git-repo>

修改远程仓库的地址

git remote set-url origin <git-repo>

列出所有的远程仓库

git remote -v

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

git remote show origin

推送与拉取



设置默认推送策略为 simple

git config push.default simple

推送 master 到远程仓库

git push origin master

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

git push -u origin master

推送时忽略 pre-push hook

git push -n

从远程仓库拉取文件

git pull origin master

设置 rebase 模式拉取代码

git pull --rebase origin master

提交



提交

git commit -m <message>

追加提交重置提交信息

git commit --amend -m <message>

重置作者

git commit --amend --author=<mail>

允许空提交

git commit --allow-empty

提交时跳过 pre-commit hook

git commit -n

日志



显示提交日志

git log

显示某文件的提交日志

git log -p <file>

以图表形式显示提交日志

git log --graph --all --oneline --decorate

显示每次提交的对象信息

git log --pretty=raw

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

git log --since '2 days ago'

显示指定作者的提交信息

git log --author=<author>

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

git log --grep=<keyword>

列出二者特有的提交

git log master...develop

列出 branch 有而 branch2 没有的提交

git log branch2..branch

仅显示 merge commit

git log --merges

统计每个作者的提交情况

git shortlog

统计每个作者的提交个数

git shortlog -sn

标签



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

git tag -ln

添加一个标签

git tag -a v1.0.0 -m <message>

在某个 commit 上添加一个标签

git tag v0.9.0 <commit>

删除一个标签

git tag -d v1.0.0

查看某个标签信息

git show v1.0.0

推送所有标签到远程仓库

git push --tags

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

git describe

追责(甩锅)



找到最后一次提交的作者

git blame <file>

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

git blame -L 10,18 <file>

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

git log -p <file>

确认坏的提交



二分查找坏的提交

git bisect start

git checkout HEAD~20

git bisect good

git bisect bad

git bisect reset

暂存区文件



列出暂存区文件

git ls-files

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

git ls-files -o

子目录中显示所在位置

git ls-files --full-name

git 对象



获取改摘要信息的类型

git cat-file -t <hash>

获取改摘要信息的内容

git cat-file -p <hash>

查找



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

git grep -n hello

打包



打包

git archive -o arch.zip HEAD
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,999评论 4 368
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,102评论 1 302
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 110,709评论 0 250
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,439评论 0 217
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,846评论 3 294
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,881评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,062评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,783评论 0 205
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,517评论 1 248
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,762评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,241评论 1 264
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,568评论 3 260
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,236评论 3 241
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,145评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,941评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,965评论 2 283
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,802评论 2 275

推荐阅读更多精彩内容

  • Git是目前最流行的版本管理系统,也是最先进的分布式版本控制系统(distributed version cont...
    pro648阅读 5,587评论 1 17
  • git常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,384评论 1 26
  • 以下笔记主要参考gitgot,大致了解git使用和原理。 第一部分我们从个人的视角去研究如何用好Git,并且揭示G...
    carolwhite阅读 2,295评论 0 1
  • ——读维多利亚·希斯洛普的《岛》 一切真相大白,伤口暴露在空气中,有一天迟早会痊愈,虽留下疤痕,却不再疼...
    老栾乱弹阅读 488评论 0 3
  • 刚刚写完一幅字,世界不知何时安静下来。还没到深夜却已经万籁俱寂。 今天外面下起了小雨,路上湿湿的,树枝上挂满了嫩绿...
    朝露_花婆婆阅读 306评论 0 0