前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Git命令行备忘录

Git命令行备忘录

作者头像
童欧巴
发布2020-05-15 11:28:43
5890
发布2020-05-15 11:28:43
举报
文章被收录于专栏:前端食堂前端食堂

Git 的命令实在是太多了,有的小伙伴就说了,我可以用客户端(Source Tree、Gitkraken、tortoiseGit)它们不香吗?

通常情况下,一些简单操作是香的。但是建议你不要越过命令行这座山而直接去使用 GUI。(而且强烈建议学习一下 Git 的原理)

先不论 GUI 是否支持复杂的操作,当你在实际工作中遇到问题的时候,可能你无法找到 GUI 的解决方案,因为搜索引擎查出来的都是命令行。而且命令行的错误提示是非常详细的,你可以准确锁定你错误的原因以及正确的使用方法,孰能自然生巧。

其次,程序员使用命令行是一件多么酷的事情啊,在黑框框里操作的时候难道没有一种黑客既视感吗?这不就是小时候梦想着成为的样子么?:)

请你给你的热爱多一点点坚持!

本文整理了一些常用的 Git 操作,老司机可以温故知新,新手可以点赞收藏。文末提供了入门教程及学习资源,请自行下滑~

配置操作

全局配置

代码语言:javascript
复制
git config --global user.name '你的名字'
git config --global user.email '你的邮箱'

当前仓库配置

代码语言:javascript
复制
git config --local user.name '你的名字'
git config --local user.email '你的邮箱'

查看 global 配置

代码语言:javascript
复制
git config --global --list

查看当前仓库配置

代码语言:javascript
复制
git config --local --list

删除 global 配置

代码语言:javascript
复制
git config --unset --global 要删除的配置项

删除当前仓库配置

代码语言:javascript
复制
git config --unset --local 要删除的配置项

本地操作

查看变更情况

代码语言:javascript
复制
git status

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

代码语言:javascript
复制
git add .

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

代码语言:javascript
复制
git add -A

将指定文件添加到暂存区

代码语言:javascript
复制
git add 文件1 文件2 文件3

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

代码语言:javascript
复制
git diff

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

代码语言:javascript
复制
git diff 文件

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

代码语言:javascript
复制
git diff --cached

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

代码语言:javascript
复制
git diff --cached 文件

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

代码语言:javascript
复制
git diff HEAD 文件

创建 commit

代码语言:javascript
复制
git commit

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

代码语言:javascript
复制
git checkout 文件1 文件2 文件3

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

代码语言:javascript
复制
git reset 文件1 文件2 文件3

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

代码语言:javascript
复制
git reset --hard

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

代码语言:javascript
复制
git difftool 提交1 提交2

查看哪些文件没被 Git 管控

代码语言:javascript
复制
git ls-files --others

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

代码语言:javascript
复制
git stash

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

  • pop 不保留 stash
  • apply 保留 stash
代码语言:javascript
复制
git stash pop
代码语言:javascript
复制
git stash apply

查看所有 stash

代码语言:javascript
复制
git stash list

取回某次 stash 的变更

代码语言:javascript
复制
git stash pop stash@{数字n}

优雅修改最后一次 commit

代码语言:javascript
复制
git add.
git commit --amend

分支操作

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

代码语言:javascript
复制
git branch -v

查看本地和远端分支

代码语言:javascript
复制
git branch -av

查看远端分支

代码语言:javascript
复制
git branch -rv

切换到指定分支

代码语言:javascript
复制
git checkout 指定分支

基于当前分支创建新分支

代码语言:javascript
复制
git branch 新分支

基于指定分支创建新分支

代码语言:javascript
复制
git branch 新分支 指定分支

基于某个 commit 创建分支

代码语言:javascript
复制
git branch 新分支 某个 commit 的 id

创建并切换到该分支

代码语言:javascript
复制
git checkout -b 新分支

安全删除本地某分支

代码语言:javascript
复制
git branch -d 要删除的分支

强行删除本地某分支

代码语言:javascript
复制
git branch -D 要删除的分支

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

代码语言:javascript
复制
git branch --merged master | grep -v '^\*\| master' | xargs -n 1 git branch -d 

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

代码语言:javascript
复制
git remote prune orign

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

代码语言:javascript
复制
git merge A分支

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

代码语言:javascript
复制
git merge A分支 B分支

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

代码语言:javascript
复制
git rebase B分支

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

代码语言:javascript
复制
git rebase B分支 A分支

变更历史

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

代码语言:javascript
复制
git log --oneline

显示就近的 n 个 commit

代码语言:javascript
复制
git log -n

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

代码语言:javascript
复制
git log --oneline --graph --all

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

代码语言:javascript
复制
git log 文件

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

代码语言:javascript
复制
git blame 文件

标签操作

查看已有标签

代码语言:javascript
复制
git tag

新建标签

代码语言:javascript
复制
git tag v1.0

新建带备注标签

代码语言:javascript
复制
git tag -a v1.0 -m '前端食堂'

给指定的 commit 打标签

代码语言:javascript
复制
git tag v1.0 commitid

推送一个本地标签

代码语言:javascript
复制
git push origin v1.0

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

代码语言:javascript
复制
git push origin --tags  

删除一个本地标签

代码语言:javascript
复制
git tag -d v1.0

删除一个远端标签

代码语言:javascript
复制
git push origin :refs/tags/v1.0

远端交互

查看所有远端仓库

代码语言:javascript
复制
git remote -v

添加远端仓库

代码语言:javascript
复制
git remote add url

删除远端仓库

代码语言:javascript
复制
git remote remove remote的名称

重命名远端仓库

代码语言:javascript
复制
git remote rename 旧名称 新名称

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

代码语言:javascript
复制
git fetch remote

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

代码语言:javascript
复制
git pull origin 分支名

将本地分支 push 到远端

代码语言:javascript
复制
git push origin 分支名

删除远端分支

代码语言:javascript
复制
git push remote --delete 远端分支名
代码语言:javascript
复制
git push remote :远端分支名

参考及 Git 学习资源

  • 玩转 Git 三剑客 苏玲
  • 阮一峰 Git 工作流程 http://www.ruanyifeng.com/blog/2015/12/git-workflow.html/
  • 廖雪峰的 Git 教程 https://www.liaoxuefeng.com/wiki/896043488029600/896067008724000/
  • awesome-git https://github.com/dictcp/awesome-git/
  • 小姐姐手把手教你动画图解 Git 命令 https://dev.to/lydiahallie/cs-visualized-useful-git-commands-37p1/
  • 17k Star的学习 Git 游戏 https://github.com/pcottle/learnGitBranching/
  • Github 官方教程 https://lab.github.com/
  • Git commit message 规范 https://juejin.im/post/5d0b3f8c6fb9a07ec07fc5d0/
  • 这才是真正的Git——Git内部原理揭秘! https://zhuanlan.zhihu.com/p/96631135
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-05-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端食堂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 配置操作
    • 全局配置
      • 当前仓库配置
        • 查看 global 配置
          • 查看当前仓库配置
            • 删除 global 配置
              • 删除当前仓库配置
              • 本地操作
                • 查看变更情况
                  • 将当前目录及其子目录下所有变更都加入到暂存区
                    • 将仓库内所有变更都加入到暂存区
                      • 将指定文件添加到暂存区
                        • 比较工作区和暂存区的所有差异
                          • 比较某文件工作区和暂存区的差异
                            • 比较暂存区和 HEAD 的所有差异
                              • 比较某文件暂存区和 HEAD 的差异
                                • 比较某文件工作区和 HEAD 的差异
                                  • 创建 commit
                                    • 将工作区指定文件恢复成和暂存区一致
                                      • 将暂存区指定文件恢复成和 HEAD 一致
                                        • 将暂存区和工作区所有文件恢复成和 HEAD 一样
                                          • 用 difftool 比较任意两个 commit 的差异
                                            • 查看哪些文件没被 Git 管控
                                              • 将未处理完的变更先保存到 stash 中
                                                • 临时任务处理完后继续之前的工作
                                                  • 查看所有 stash
                                                    • 取回某次 stash 的变更
                                                      • 优雅修改最后一次 commit
                                                      • 分支操作
                                                        • 查看当前工作分支及本地分支
                                                          • 查看本地和远端分支
                                                            • 查看远端分支
                                                              • 切换到指定分支
                                                                • 基于当前分支创建新分支
                                                                  • 基于指定分支创建新分支
                                                                    • 基于某个 commit 创建分支
                                                                      • 创建并切换到该分支
                                                                        • 安全删除本地某分支
                                                                          • 强行删除本地某分支
                                                                            • 删除已合并到 master 分支的所有本地分支
                                                                              • 删除远端 origin 已不存在的所有本地分支
                                                                                • 将 A 分支合入到当前分支中且为 merge 创建 commit
                                                                                  • 将 A 分支合入到 B 分支中且为 merge 创建 commit
                                                                                    • 将当前分支基于 B 分支做 rebase,以便将B分支合入到当前分支
                                                                                      • 将 A 分支基于 B 分支做 rebase,以便将 B 分支合入到 A 分支
                                                                                      • 变更历史
                                                                                        • 当前分支各个 commit 用一行显示
                                                                                          • 显示就近的 n 个 commit
                                                                                            • 用图示显示所有分支的历史
                                                                                              • 查看涉及到某文件变更的所有 commit
                                                                                                • 某文件各行最后修改对应的 commit 以及作者
                                                                                                • 标签操作
                                                                                                  • 查看已有标签
                                                                                                    • 新建标签
                                                                                                      • 新建带备注标签
                                                                                                        • 给指定的 commit 打标签
                                                                                                          • 推送一个本地标签
                                                                                                            • 推送全部未推送过的本地标签
                                                                                                              • 删除一个本地标签
                                                                                                                • 删除一个远端标签
                                                                                                                • 远端交互
                                                                                                                  • 查看所有远端仓库
                                                                                                                    • 添加远端仓库
                                                                                                                      • 删除远端仓库
                                                                                                                        • 重命名远端仓库
                                                                                                                          • 将远端所有分支和标签的变更都拉到本地
                                                                                                                            • 把远端分支的变更拉到本地,且 merge 到本地分支
                                                                                                                              • 将本地分支 push 到远端
                                                                                                                                • 删除远端分支
                                                                                                                                • 参考及 Git 学习资源
                                                                                                                                领券
                                                                                                                                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档