Git常用命令图文解析

一、新建仓库


1.在当前目录新建一个Git仓库

$ git init



2.新建一个目录,并将其初始化为Git仓库

$ git init helloworld
说明:创建一个helloworld目录,在其下创建Git仓库。


3.从远程GitHub克隆一个仓库下来

$ git clone https://github.com/yangyile/helloworld


二、配置


Git的设置文件为.gitconfig,它可以在用户主目录下(全局配置),也可以在项目目录下(项目配置)。

1.显示当前的Git配置

$ git config --list




2.编辑Git配置文件

$ git config -e [--global]


敲入命令git config -e --global即可编辑Git全局配置,编辑完成:wq保存退出。


3.设置提交代码时的用户信息

$ git config [--global] user.name "[name]"
$ git config [--global] user.email "[email address]"



三、增加/删除文件


1.添加指定文件到暂存区

$ git add [file1] [file2] ...

如:git add test1.html


2.添加指定目录到暂存区,包括子目录

$ git add [dir]
如:git add test,即将test文件夹放到暂存区

3.添加当前目录的所有文件到暂存区

$ git add .


4.对于一个文件的多处变化,可以实现分次提交

$ git add -p


5.删除工作区文件,并且将这次删除放入暂存区

$ git rm [file1] [file2] ...


6.停止追踪指定文件,但该文件会保留在工作区

$ git rm --cached [file]


7.改名文件,并且将这个改名放入暂存区

$ git mv [file-original] [file-renamed]


四、代码提交


1.提交暂存区到仓库

$ git commit -m [message]


2.提交暂存区的指定文件到仓库

$ git commit [file1] [file2] ... -m [message]


3.提交工作区自上次commit之后的变化,直接到仓库

$ git commit -a


4.使用一次新的commit,替代上一次提交,如果代码没有任何新的变化,则用来改写上一次commit的提交信息

$ git commit --amend -m [message]


5.重做上次commit,并包括制定文件的新变化

$ git commit --amend [file1] [file2] ...


五、分支


1.列出所有本地分支

$ git branch


2.列出所有远程分支


3.列出所有本地分支和远程分支

$ git branch -a


4.新建一个分支,但依然停留在当前分支

$ git branch [branch-name]

如:git branch branch1


5.新建一个分支,并却换到该分支

$ git checkout -b [branch]


6.新建一个分支,指向指定的commit

$ git branch [branch] [commit]


7.新建一个分支,与指定的远程分支建立追踪关系



8.切换到指定分支,并更新工作区

$ git checkout [branch-name]


9.切换到上一个分支

$ git checkout -


10.合并指定分支到当前分支

$ git merge [branch]


11.删除分支

$ git branch -d [branch-name]


12.删除远程分支

$ git push origin --delete [branch-name]
$ git branch -dr [remote/branch]


13.创建一个全新的分支,不包含原分支的提交历史

$ git checkout --orphan [new-branch]


14.将master上的修改同步至分支

$ git rebase master branch1
说明:当前分支为branch1,如果想要将master上的修改同步至branch1,可执行上述命令(上述命令相当于git checkout branch1, git rebase master。会基于master将branch1的提交重做)。

六、标签


1.列出所有tag

$ git tag


2.新建一个tag在当前commit

$ git tag [tag]
如执行git tag tag1命令,会在helloworld仓库的refs下看到新建的tag1分支。


3.新建一个tag在指定commit

$ git tag [tag] [commit]


4.删除本地tag

$ git tag -d [tag]


5.删除远程tag

$ git push origin :refs/tags/[tagName]


6.查看tag信息

$ git show [tag]


7.提交指定tag

$ git push [remote] [tag]


8.提交所有tag

$ git push [remote] --tags


9.新建一个分支,指向某个tag

$ git checkout -b [branch] [tag]


七、查看信息


1.显示有变更的文件

$ git status



2.显示当前分支的版本历史

$ git log


3.显示commit历史,以及每次commit发生变更的文件

$ git log -S [Keyword]


4.显示某个commit之后的所有变动,每个commit占据一行

$ git log [tag] HEAD --pretty=format:%s


5.显示某个commit之后的所有变动,其“提交说明”必须符合搜索条件

$ git log [tag] HEAD --grep feature


6.显示某个文件的版本历史,包括文件改名

$ git log --follow [file]
$ git whatchanged [file]


7.显示指定文件相关的每一次diff

$ git log -p [file]


8.显示过去5次提交

$ git log -5 --pretty --oneline


9.显示所有提交过的用户,按提交次数排序

$ git shortlog -sn


10.显示指定文件是什么人在什么时间修改过

$ git blame [file]


11.显示暂存区和工作区的差异

$ git diff


12.显示暂存区和上一个commit的差异

$ git diff --cached [file]


13.显示工作区与当前分支最新commit之间的差异



14.显示两次提交之间的差异

$ git diff [first-branch]...[second-branch]


15.显示今天你写了多少行代码

$ git diff --shortstat "@{0 day ago}"

4 insertions显示插入了4行代码


16.显示某次提交的元数据和内容变化

$ git show [commit]


17.显示某次提交发生变化的文件

$ git show --name-only [commit]


18.显示某次提交时,某个文件的内容

$ git show [commit]:[filename]


19.显示当前分支的最近几次提交

$ git reflog


20.查看当前分支下每次提交的详细信息

$ gitk
说明:如果安装了SourceTree,可以直接调出图形界面,如下:



八、远程同步


1.下载远程仓库的所有变动
$ git fetch [remote]

2.显示所有远程仓库
$ git remote -v


3.显示某个远程仓库的信息
$ git remote show [remote]

3.增加一个新的远程仓库,并命名
$ git remote add [shortname] [url]


4.取回远程仓库的变化,并与本地分支合并
$ git pull [remote] [branch]

5.上传本地指定分支到远程仓库
$ git push [remote] [branch]

6.强行推送当前分支到远程仓库,即使有冲突
$ git push [remote] --force


7.推送所有分支到远程仓库
$ git push [remote] --all


九、撤销


1.恢复暂存区的指定文件到工作区
$ git checkout [file]

2.恢复某个commit的指定文件到暂存区和工作区
$ git checkout [commit] [file]

3.恢复暂存区的所有文件到工作区
$ git checkout

4.重置暂存区的指定文件,与上一次commit保持一致,但工作区不变
$ git reset [file]

5.重置暂存区与工作区,与上一次commit保持一致
$ git reset --hard

6.重置当前分支的指针为指定commit,同时重置暂存区,但工作区不变
$ git reset [commit]

重置了暂存区,但是工作区没变。

7.重置当前分支的HEAD为指定commit,同时重置暂存区和工作区,与指定commit一致
$ git reset --hard [commit]
暂存区和工作区都被重置为0b5f656

8.重置当前HEAD为指定commit,但保持暂存区和工作区不变
$ git reset --keep [commit]

9.新建一个commit,用来撤销指定commit,后者的所有变化将被前者抵消,并且应用到当前分支
$ git revert [commit]

10.暂时将未提交的变化移除,稍后再移入
$ git stash
$ git stash pop

十、Git调试


说明:git blame在你知道问题是哪里引入的时候会有帮助。如果你不知道,并且自上次代码可用的状态已经经历了上百次的提交,你可能就要求助于bisect命令了。bisect会在你的提交历史中进行二分查找来尽快地确定哪一次提交引入了错误。如在标记为good和bad版本间检出一个分支,经测试后发现不是该版本引入的,则用git bisect good做标记,然后继续在good和bad之间检出版本。直到找到出现错误的那个版本,然后标记为git bisect bad,然后显示提交说明以及那些文件在哪次提交里修改过。
1.启动bisect查找
$ git bisect start

2.确定当前分支有问题
$ git bisect bad

3.必须告诉bisect已知的最后一次正常状态是哪次提交
$ git bisect good v1.0

4.重置bisect
$ git bisect reset

5.设置脚本自动测试,在脚本中,对于错误的测试返回0,非错误的测试返回非0
$ git bisect start HEAD v1.0
$ git bisect run test-error.sh

十一、其它


1.生成一个可供发布的压缩包
$ git archive

猜你喜欢

转载自blog.csdn.net/y2010081134/article/details/72561620