常用的Git便捷操作合集
作者:carverZhong 发布时间:2022-02-19 08:16:47
1.Fork出来的Git仓库同步代码
背景:有的时候从原仓库fork出了一个新仓库,这个新仓库做了自己的修改。可是原仓库也进行了更新,比如修复了bug,增加了新特性之类的。这个时候想要把原仓库代码同步过来。
原理:把原仓库的代码拉到本地,然后通过git merge
把原仓库分支代码合到自己的分支代码。
1.先拉取原仓库代码到本地
git remote add upstream (填写你仓库git地址)
git fetch upstream
这样就把原仓库代码拉到本地了,而且 upstream 跟原仓库进行了绑定。(类似origin的绑定,upstream 也可以命名为其它的名称)
此时执行git remote
,会看到有两个:
origin
remote
2.合并分支
切换到fork仓库的分支,可以新建一个合并分支。然后执行命令:
# 分支名不一定得是master,也可以是其它的原仓库分支。
git merge upstream/master
如果有冲突就要解决冲突,解决完执行下命令即可:
git merge --continue
最后,如果完成了,可以执行命令移除这个绑定。
git remote remove upstream
2.合并多个提交
完成一小部分功能进行提交是一个良好的习惯,有利于我们随时回溯代码。然而整体功能没完成是不能提交到主干的,而且也倾向于整体功能完成合并为一个提交。因此本地的多个小提交合并成一个提交就很有必要了。下面举个栗子演示合并操作。
执行git log
,查看历史提交:
commit 03c72b6dfc24c6bf6f60e2c922552249cc3e5376
git test 3
commit 24276fbd0495c4b337f4058726a48e68118eac0a
git test 2
commit 9f92d8624a3adf7cd6fb69268f99d864390838c4
git test 1
假设要将前两笔提交合并,则记录下第三笔的commitId:9f92d8624a3adf7cd6fb69268f99d864390838c4
。(第三笔提交不参与合并)
执行以下命令:
git rebase -i 9f92d8624a3adf7cd6fb69268f99d864390838c4
执行后会弹出以下:
pick 24276fbd git test 2
pick 03c72b6d git test 3
# 省略以下内容
此时要将除第一个外的pick改为squash或者s。即改完后为:
pick 24276fbd git test 2
s 03c72b6d git test 3
# 省略以下内容
改完保存退出,会弹出commit message修改界面,修改保存即可。
再执行git log
发现提交已经合并了。
commit 980d318f91f2faa1d748ae5a963b692162dd521c
git test merge
commit 9f92d8624a3adf7cd6fb69268f99d864390838c4
git test 1
3.代码回退
1、在工作区的代码
# 丢弃某个文件
git checkout -- 文件名
# 丢弃全部
git checkout -- .
2、git add
到了索引区
# 回退索引区所有文件
git reset HEAD .
# 回退索引区指定文件夹
git reset HEAD 文件夹名
3、commit 到本地分支的代码
# 回退最新一笔提交
git reset --hard HEAD^
# 回退到指定的版本
git reset --hard 版本号
这里说下reset时,指定--hard、--soft、--mixed的区别:
hard: 回退时HEAD指针被回退,索引区、工作目录都被重置了。
soft: 只改变了历史提交(HEAD指针),索引区和工作目录没有更改。
mixed: 不指定时默认为mixed,改变了历史提交(HEAD指针),重置了索引区。
4.使用worktree
当你的项目很大,而有多个特性需要开发时,为了避免频繁切换分支,可以使用git worktree
。
git worktree
非常适合大型项目又需要维护多个分支,想要避免来回切换的场景。其有以下几个优点:
单独 clone 项目相比,节省了硬盘空间,又因为 git worktree 使用 hard link 实现,要远远快于 clone
提交可以在同一个项目中共享
可以快速进行并行开发,同一个项目多个分支同时并行演进
git worktree
使用非常简单,掌握3个命令即可:
# 添加一个 worktree。
git worktree add filePath
# 移除一个 worktree
git worktree remove filePath
# 查看目前所有的 worktree
git worktree list
创建了worktree
后,只需要用IDE打开添加到filePath
的项目即可。
5.其它
#本地分支与远程进行关联
git branch --set-upstream-to=origin/(要关联的分支名)
#推送本地新建分支到远端分支(远端会自动创建分支)
git push origin newbranch:originbranch
#删除远端分支
git push origin --delete (branch_name)
#查看本地分支关联的远程分支
git branch -vv
#分支重命名
git branch -m oldName newName
#修改当前项目的用户名和邮箱
git config --local user.name “userName"
git config --local user.email email@example.com
#删除本地版本库上那些失效的远程追踪分支:
git remote prune origin --dry-run
来源:https://www.cnblogs.com/carverzhong/p/16732187.html


猜你喜欢
- 这里批量处理word文档的操作主要是通过python-docx非标准库实现的,通过定位到文档对象、再到段落、最后到一行文本从而完成针对文字对
- 定义行为要定义行为,通过继承 yii\base\Behavior 或其子类来建立一个类。如:namespace app\components
- 我的原数据库是3.23版本的.前几天因为一个论坛转移.必须用5.1的.于是就是升级了数据库.论坛是正常的.可以是原来的一个老库因为是3.23
- 一、背景起源于一个问题:怎样找到字符串中出现次数最多的字符其实使用max函数就能很轻松的解决这个问题:代码:str1 = "AAA
- 我们在.NET程序的开发过程中,常常需要和用户进行信息交互,比如执行某项操作是否成功,“确定”还是“取消”,以及选择“确定”或“取消”后是否
- 在一群里有朋友发问,有时间,也就看看了,不多说了,看图了:用一般的 select .... order 排序出来,就如下图了,是
- 在 Python 整型对象所存储的位置是不同的, 有一些是一直存储在某个存储里面, 而其它的, 则在使用时开辟出空间.说这句话的理由, 可以
- 使用opencv-python,把一段视频中指定帧频间隔的图像保存到新建的文件中首先安装好python ,配置好opencv-python#
- Python自动化办公之删除重复的视频文件获取所有文件路径import osimport filecmpfile_list=[]new_li
- 概念第一步:计算一个梯度 Ix,Iy第二步:整合矩阵,计算特征值第三步:比较特征值的大小第四步: 非极大值抑制,把真正的角点留下来,角点周围
- 一个常常令设计师和前端开发人员都头疼的事情就是字体的使用,设计师常常在设计稿中使用某些很漂亮的字体,以实现比较酷炫的界面。但这样常常给编码人
- 背景:有一个list,里面的每一个元素都是dict,根据某一个key进行去重,在这里,key代表question#!/usr/bin/env
- 一、背景分析对想要在视觉化环境下制作复杂网页的专业网页制作者来说,Dreamweaver已经渐渐在网页编辑工具中展露头角,成为专业人士编写网
- 我们在工作中经常强调沟通能力,和产品、开发、测试等不同角色的人需要沟通,和领导、同事需要沟通,沟通是一个双向的过程,而沟通首先需要双方有良好
- 一、写在前面从学 Python 的第一天起,我就知道了使用 pip 命令来安装包,从学习爬虫到学习 Web 开发,安装的库越来越多,从 re
- 爬虫请求头网页获取:通过urlopen来进行获取requset.urlopen(url,data,timeout)第一个参数url即为URL
- 本人自己写过三个图片轮播,一个是简单的原生JS实现的,没有什么动画效果的,一个是结合JQuery实现的,淡入淡出切换的。现在想做一个酷一点的
- 在进行接口自动化测试时,有好多接口都基于登陆接口的响应值来关联进行操作的,在次之前试了很多方法,都没有成功,其实很简单用session来做。
- 这篇文章主要介绍了python函数不定长参数使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的
- 纯粹的截取字符串其实比较简单,用一个Left就搞定,但一个是全英文标题,一个是全中文标题,或中文混合排在一起,长短不一就很明显了,要考虑到中