Git常用命令合集

Git常用命令合集

# 第一次初始化(方式1):

git init

git add .

git commit -m 'first commit'

git remote add origin git@github.com:帐号名/仓库名.git

git pull origin master

git push origin master # -f 强推

# 第一次初始化(方式2):

git clone git@github.com:git帐号名/仓库名.git

# 平时工作基本操作:

git checkout master # 切到主分支

git fetch origin  # 获取最新变更

git checkout -b dev origin/master # 基于主分支创建dev分支

git add . # 添加到缓存

git commit -m 'xxx' # 提交到本地仓库

git fetch origin # 获取最新变更

git rebase dev origin/master # 合并到主分支

git push origin dev # 推送到远程分支git chekout master # 切到主分支git merge dev # 合并开发分支git clone -b 远程分支 仓库地址 # 本地不存在仓库 拉取远程分支代码git checkout -b 远程分支 origin/远程分支 # 本地存在仓库,拉取远程分支

# 初始化仓库

git init

# 查看仓库当前状态

git status

# 将文件添加到仓库

git add 文件名 # 将工作区的某个文件添加到暂存区   

git add . # 将当前工作区的所有文件都加入暂存区

git add -u # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件

git add -A # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件

git add -i # 进入交互界面模式,按需添加文件到缓存区

# 将暂存区文件提交到本地仓库

git commit -m "提交说明" # 将暂存区内容提交到本地仓库

git commit -a -m "提交说明" # 跳过缓存区操作,直接把工作区内容提交到本地仓库

# 比较文件异同

git diff # 工作区与暂存区的差异

git diff 分支名 #工作区与某分支的差异,远程分支这样写:remotes/origin/分支名

git diff HEAD  # 工作区与HEAD指针指向的内容差异

git diff 提交id 文件路径 # 工作区某文件当前版本与历史版本的差异

git diff --stage # 工作区文件与上次提交的差异(1.6 版本前用 --cached)

git diff 版本TAG # 查看从某个版本后都改动内容

git diff 分支A 分支B # 比较从分支A和分支B的差异(也支持比较两个TAG)

git diff 分支A...分支B # 比较两分支在分开后各自的改动

# 另外:如果只想统计哪些文件被改动,多少行被改动,可以添加 --stat 参数

# 查看历史记录

git log # 查看所有commit记录(SHA-A校验和,作者名称,邮箱,提交时间,提交说明)

git log -p -次数 # 查看最近多少次的提交记录

git log --stat # 简略显示每次提交的内容更改

git log --name-only # 仅显示已修改的文件清单

git log --name-status # 显示新增,修改,删除的文件清单

git log --oneline # 让提交记录以精简的一行输出

git log –graph –all --online # 图形展示分支的合并历史

git log --author=作者  # 查询作者的提交记录(和grep同时使用要加一个--all--match参数)

git log --grep=过滤信息 # 列出提交信息中包含过滤信息的提交记录

git log -S查询内容 # 和--grep类似,S和查询内容间没有空格

git log fileName # 查看某文件的修改记录,找背锅专用

# 代码回滚

git reset HEAD^ # 恢复成上次提交的版本

git reset HEAD^^ # 恢复成上上次提交的版本,就是多个^,以此类推或用~次数

git reflog

git reset --hard 版本号

--soft:只是改变HEAD指针指向,缓存区和工作区不变;

--mixed:修改HEAD指针指向,暂存区内容丢失,工作区不变;

--hard:修改HEAD指针指向,暂存区内容丢失,工作区恢复以前状态;

# 同步远程仓库

git push -u origin master

# 删除版本库文件

git rm 文件名

# 版本库里的版本替换工作区的版本

git checkout -- test.txt

# 本地仓库内容推送到远程仓库

git remote add origin git@github.com:帐号名/仓库名.git

# 从远程仓库克隆项目到本地

git clone git@github.com:git帐号名/仓库名.git

# 创建分支

git checkout -b dev

-b表示创建并切换分支

上面一条命令相当于一面的二条:

git branch dev //创建分支

git checkout dev //切换分支

# 查看分支

git branch

# 合并分支

git merge dev  #用于合并指定分支到当前分支

git merge --no-ff -m "merge with no-ff" dev  #加上--no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并

# 删除分支

git branch -d dev

# 查看分支合并图

git log --graph --pretty=oneline --abbrev-commit

# 查看远程库信息

git remote

# git相关配置

# 安装完Git后第一件要做的事,设置用户信息(global可换成local在单独项目生效):

git config --global user.name "用户名" # 设置用户名

git config --global user.email "用户邮箱"   #设置邮箱

git config --global user.name   # 查看用户名是否配置成功

git config --global user.email   # 查看邮箱是否配置

# 其他查看配置相关

git config --global --list  # 查看全局设置相关参数列表

git config --local --list # 查看本地设置相关参数列表

git config --system --list # 查看系统配置参数列表

git config --list  # 查看所有Git的配置(全局+本地+系统)

git config --global color.ui true //显示git相关颜色

# 撤消某次提交

git revert HEAD # 撤销最近的一个提交

git revert 版本号 # 撤销某次commit

# 拉取远程分支到本地仓库

git checkout -b 本地分支 远程分支 # 会在本地新建分支,并自动切换到该分支

git fetch origin 远程分支:本地分支 # 会在本地新建分支,但不会自动切换,还需checkout

git branch --set-upstream 本地分支 远程分支 # 建立本地分支与远程分支的链接

# 标签

git tag 标签 //打标签命令,默认为HEAD

git tag //显示所有标签

git tag 标签 版本号 //给某个commit版本添加标签

git show 标签 //显示某个标签的详细信息

# 同步远程仓库更新

git fetch  origin master

一、配置操作

1、全局配置

git config --global user.name '你的名字'

git config --global user.email '你的邮箱'

2、当前仓库配置

git config --local user.name '你的名字'

git config --local user.email '你的邮箱

3、查看 global 配置

git config --global --list

4、查看当前仓库配置

git config --local --list

5、删除 global 配置

git config --unset --global 要删除的配置项

6、删除当前仓库配置

git config --unset --local 要删除的配置项

二、本地操作

1、查看变更情况

git status

2、将当前目录及其子目录下所有变更都加入到暂存区

git add .

3、将仓库内所有变更都加入到暂存区

git add -A

4、将指定文件添加到暂存区

git add 文件1 文件2 文件3

5、比较工作区和暂存区的所有差异

git diff

6、比较某文件工作区和暂存区的差异

git diff 文件

7、比较暂存区和 HEAD 的所有差异

git diff --cached

8、比较某文件暂存区和 HEAD 的差异

git diff --cached 文件

9、比较某文件工作区和 HEAD 的差异

git diff HEAD 文件

10、创建 commit

git commit

11、将工作区指定文件恢复成和暂存区一致

git checkout 文件1 文件2 文件3

12、将暂存区指定文件恢复成和 HEAD 一致

git reset 文件1 文件2 文件3

13、将暂存区和工作区所有文件恢复成和 HEAD 一样

git reset --hard

14、用 difftool 比较任意两个 commit 的差异

git difftool 提交1 提交2

15、查看哪些文件没被 Git 管控

git ls-files --others

16、将未处理完的变更先保存到 stash 中

git stash

17、临时任务处理完后继续之前的工作

pop 不保留 stashapply 保留 stashgit stash popgit stash apply

18、查看所有 stash

git stash list

19、取回某次 stash 的变更

git stash pop stash@{数字n}

20、优雅修改最后一次 commit

git add. git commit --amend

三、分支操作

1、查看当前工作分支及本地分支

git branch -v

2、查看本地和远端分支

git branch -av

3、查看远端分支

git branch -rv

4、切换到指定分支

git checkout 指定分支

5、基于当前分支创建新分支

git branch 新分支

6、基于指定分支创建新分支

git branch 新分支 指定分支

7、基于某个 commit 创建分支

git branch 新分支 某个 commit 的 id

8、创建并切换到该分支

git checkout -b 新分支

9、安全删除本地某分支

git branch -d 要删除的分支

10、强行删除本地某分支

git branch -D 要删除的分支

11、删除已合并到 master 分支的所有本地分支

git branch --merged master | grep -v '^\*\| master' | xargs -n 1 git branch -d

12、删除远端 origin 已不存在的所有本地分支

git remote prune orign

13、将 A 分支合入到当前分支中且为 merge 创建 commit

git merge A分支

14、将 A 分支合入到 B 分支中且为 merge 创建 commit

git merge A分支 B分支

15、将当前分支基于 B 分支做 rebase,以便将B分支合入到当前分支

git rebase B分支

16、将 A 分支基于 B 分支做 rebase,以便将 B 分支合入到 A 分支

git rebase B分支 A分支

四、变更历史

1、当前分支各个 commit 用一行显示

git log --oneline

2、显示就近的 n 个 commit

git log -n

3、用图示显示所有分支的历史

git log --oneline --graph --all

4、查看涉及到某文件变更的所有 commit

git log 文件

5、某文件各行最后修改对应的 commit 以及作者

git blame 文件

五、标签操作

1、查看已有标签

git tag

2、新建标签

git tag v1.0

3、新建带备注标签

git tag -a v1.0 -m '前端食堂'

4、给指定的 commit 打标签

git tag v1.0 commitid

5、推送一个本地标签

git push origin v1.0

6、推送全部未推送过的本地标签

git push origin --tags

7、删除一个本地标签

git tag -d v1.0

8、删除一个远端标签

git push origin :refs/tags/v1.0

六、远端交互

1、查看所有远端仓库

git remote -v

2、添加远端仓库

git remote add url

3、删除远端仓库

git remote remove remote的名称

4、重命名远端仓库

git remote rename 旧名称 新名称

5、将远端所有分支和标签的变更都拉到本地

git fetch remote

6、把远端分支的变更拉到本地,且 merge 到本地分支

git pull origin 分支名

7、将本地分支 push 到远端

git push origin 分支名

8、删除远端分支

git push remote --delete 远端分支名 git push remote :远端分支名

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值