专栏首页前端食堂Git命令行备忘录

Git命令行备忘录

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

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

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

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

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

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

配置操作

全局配置

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

当前仓库配置

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

查看 global 配置

git config --global --list

查看当前仓库配置

git config --local --list

删除 global 配置

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

删除当前仓库配置

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

本地操作

查看变更情况

git status

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

git add .

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

git add -A

将指定文件添加到暂存区

git add 文件1 文件2 文件3

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

git diff

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

git diff 文件

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

git diff --cached

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

git diff --cached 文件

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

git diff HEAD 文件

创建 commit

git commit

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

git checkout 文件1 文件2 文件3

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

git reset 文件1 文件2 文件3

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

git reset --hard

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

git difftool 提交1 提交2

查看哪些文件没被 Git 管控

git ls-files --others

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

git stash

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

  • pop 不保留 stash
  • apply 保留 stash
git stash pop
git stash apply

查看所有 stash

git stash list

取回某次 stash 的变更

git stash pop stash@{数字n}

优雅修改最后一次 commit

git add.
git commit --amend

分支操作

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

git branch -v

查看本地和远端分支

git branch -av

查看远端分支

git branch -rv

切换到指定分支

git checkout 指定分支

基于当前分支创建新分支

git branch 新分支

基于指定分支创建新分支

git branch 新分支 指定分支

基于某个 commit 创建分支

git branch 新分支 某个 commit 的 id

创建并切换到该分支

git checkout -b 新分支

安全删除本地某分支

git branch -d 要删除的分支

强行删除本地某分支

git branch -D 要删除的分支

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

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

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

git remote prune orign

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

git merge A分支

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

git merge A分支 B分支

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

git rebase B分支

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

git rebase B分支 A分支

变更历史

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

git log --oneline

显示就近的 n 个 commit

git log -n

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

git log --oneline --graph --all

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

git log 文件

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

git blame 文件

标签操作

查看已有标签

git tag

新建标签

git tag v1.0

新建带备注标签

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

给指定的 commit 打标签

git tag v1.0 commitid

推送一个本地标签

git push origin v1.0

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

git push origin --tags  

删除一个本地标签

git tag -d v1.0

删除一个远端标签

git push origin :refs/tags/v1.0

远端交互

查看所有远端仓库

git remote -v

添加远端仓库

git remote add url

删除远端仓库

git remote remove remote的名称

重命名远端仓库

git remote rename 旧名称 新名称

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

git fetch remote

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

git pull origin 分支名

将本地分支 push 到远端

git push origin 分支名

删除远端分支

git push remote --delete 远端分支名
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

本文分享自微信公众号 - 前端食堂(webcanteen),作者:霍语佳

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2020-05-06

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 深入浅出的Vue技巧总结

    最近公司来了不少实习生和经验不是特别丰富的前端开发人员,带着他们做项目的时候,发现有很多入行0-3年的前端者欠缺一些东西。

    童欧巴
  • HTTP的世界观

    前端圈技术的爆发式增长随之而来的开发人员学不动的疲惫感、焦虑感和不想跳出舒适圈的拖延懒惰。

    童欧巴
  • 「面试心理学」面试前的思考

    面试是一直火热并广受大家关注的话题,社区内不断输出着丰富的面试题以及各大厂面经,以题目为主,经验为辅。但其实在整个面试环节中重要的不仅仅是面试题。而且,面试题具...

    童欧巴
  • 快速入门使用Git管理代码

    许可协议: 署名-非商业性使用-禁止演绎 4.0 国际 转载请保留原文链接及作者。

    Bobby
  • github学习(二)

    Git学习(一) 学习github一定要学会git,否则在后续的github运用中会出现很多问题。 1.安装Git: Mac自带Git,Windows需要自己安...

    希希里之海
  • 程序员必备基础:Git 命令全方位学习

    掌握Git命令是每位程序员必备的基础,之前一直是用smartGit工具,直到看到大佬们都是在用Git命令操作的,回想一下,发现有些Git命令我都忘记了,于是写了...

    捡田螺的小男孩
  • 使用码云新建、推拉第一个项目文件

    本地电脑安装git。可通过 git --version 查看版本,确保本机已有git。

    子乾建建-Jeff
  • 10分钟带你入门git到github

    开局先来一个故事吧,故事看完如果不想看枯燥无味的指令,没关系我已经把这篇文章的内容录制成了一个视频,点击文末阅读原文就可以观看。或者说你已经熟练掌握git的使用...

    java金融
  • Git详细操作

    1.参考帮助文档:https://gitee.com/help/ 仓库管理 =公钥管理 =生成/添加SSH公钥

    小小咸鱼YwY
  • Git常用命令总结

    ​ 在本地新建一个repo,进入一个项目目录,执行git init,会初始化一个repo,并在当前文件夹下创建一个.git文件夹.

    小小咸鱼YwY

作者介绍

精选专题

活动推荐

扫码关注云+社区

领取腾讯云代金券