百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

Git 提交错了不用慌,这三招帮你修改记录

wptr33 2025-01-16 21:11 26 浏览

作者 | 梁唐

来源 | TechFlow(ID:techflow2019)

头图 | CSDN 下载自东方IC

大家好,今天我们来聊聊 git 当中一个很重要的功能——历史记录的修改。

有的时候我们会突然发现某个地方需要修改,最常见的某个不应该被提交的文件被提交了进来。我们希望它不只是在后续的版本当中不再出现,而是希望整个从 git 仓库当中移除掉。这个时候我们就需要修改 git 之前的历史记录。这个时候应该怎么办呢?

不要着急,git 当中有很多的手段可以修改之前的历史提交记录。

修改最后一次提交

这一点我们在之前的文章当中曾经提到过,如果我们只是想要修改最后一次的提交记录,这是比较简单的。我们只需要直接修改我们想要修改的部分,在提交的时候加上一个参数 --amend 即可。

git commit --amend

amend 的意思是补丁,它可以把我们这一次的修改合并到上一条历史记录当中,而不会产生一个新的 commit 记录。运行之后,它会打开一个 vim 编辑器,我们还可以修改上一次 commit 时输入的提示信息。

我们使用 git log 检查的话,会发现历史记录的修改时间还是上一次的时间。看起来就好像什么也没有发生过一样,悄无声息地就改掉了。

修改多个信息

--amend 虽然好用,但是它只能修改最后一次的提交信息,如果我们想要修改的提交记录在那之前,我们应该怎么办呢?

git 当中并没有提供直接的工具来实现这一点,不过我们可以使用 rebase 来达成。我们可以加上-i进行交互式地变基,我们可以在任何想要的修改完成之后停止,也可以添加文件或者是做其他想要做的事情。但是我们变基的目标不是某一个分支而是当前分支的某一个历史节点,所以我们需要提供一个具体的 commitid 或者是指针位置。

git rebase -i 的功能非常强大,我们几乎可以使用它来完成所有一切我们想要完成的事情。

比如我们想要修改倒数第二次提交,我们可以执行 git rebase -i HEAD~3。也就是以倒数第三个节点作为基准节点执行变基,这时候git会进入一个vim窗口,在这个窗口当中我们可以看到最近的三次提交记录。

首先我们可以看到上面的三行就是我们可以修改的三个 commit,分别展示的是要执行的操作以及 commitid 以及 commit message。这里的操作默认的是 pick,也就是使用该 commit。关于我们可以执行的操作 git 在下方也给了充分的提示,其中比较常用的有 pick、edit 以及 squash。

这一次我们想要做的是修改提交记录,所以我们应该执行 edit,我们把想要修改的 commit 前的 pick 改成 edit。比如这样:

退出之后,git 会自动带我们回到我们选择edit的分支提交之后的版本。我们进行我们想要的修改,这里我在第15篇文章当中加上了一行:尝试 rebase。之后再使用 git add 以及 git commit --amend 进行修改提交结果。

再之后我们执行 git rebase --continue,把剩下要应用的变更应用完成。

一切都结束之后,我们可以使用一下 git show 命令查看一下我们修改的 bee9ce3 这个 commit 的记录。可以看到已经多了这一行,说明我们的修改成功了。

顺序变更、合并、拆分

1、顺序变更

我们不仅可以修改某一次 commit 当中的内容,还可以修改这些 commit 的相对顺序,以及可以让它们合并以及拆分。

修改顺序其实很简单,我们只需要人为地修改 rebase -i 之后弹出的 vim 文件即可。比如说原本的记录是:

pick A change Apick B change Bpick C change C

如果我们想要更换顺序,我们只需要修改这个文件即可。比如变成:

pick B change Bpick A change Apick C change C

那么当我们在退出 vim 的时候,git 会首先应用 B commit 的变更,再应用 A 最后应用 C。

2、合并

除此之外,我们还可以合并多个 commit 记录成一个。操作的方法也很简单,就是我们只需要把 pick 修改成 squash。git 会自动把所有 squash 的 commit 记录合并在一起。

pick A change Asquash B change Bsquash C change

3、拆分

有的时候一个 commit 非常巨大,我们可能也会想要将它拆分,其实操作也很简单。比如我们想要把 commit B 拆分成两条,首先,我们在 rebase 的时候将 commit B 前面的 pick 修改成 edit。

pick A change Aedit B change Bpick C change C

当我们退出的时候,我们会进入到 B commit 刚刚提交完的状态。由于我们要做的是拆分 B 这个提交,所以我们需要执行 git reset HEAD^,把上一次提交重置。然后再分别 add 我们想要拆分开来提交的文件。

整个操作如下:

git reset HEAD^git add test/*git ci -m 'add test'git add code/*git ci -m 'update code'git rebase --continue

这样我们就把 commit B 拆分成了两个 commit 插入到了历史记录当中了。

最后的最后,大家需要注意,虽然这些手段在修改记录的时候非常好用。但是如果这些 commit 已经被提交到了远程,我们是不可以直接 git push 同步的。因为 git 会校验我们提交的 hash 值,发现对不上之后会禁止我们的提交。所以如果想要提交到远程的话,只能使用 git push -f 强制覆盖。但是这是一个非常非常危险的操作,如果你 git push -f 了,没有人会知道你到底修改了什么,只建议在自己独有的分支上如此操作,一定一定要谨慎使用。

点分享

相关推荐

oracle数据导入导出_oracle数据导入导出工具

关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...

继续学习Python中的while true/break语句

上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个else解...

python continue和break的区别_python中break语句和continue语句的区别

python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...

简单学Python——关键字6——break和continue

Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...

Python 中 break 和 continue 傻傻分不清

大家好啊,我是大田。今天分享一下break和continue在代码中的执行效果是什么,进一步区分出二者的区别。一、continue例1:当小明3岁时不打印年龄,其余年龄正常循环打印。可以看...

python中的流程控制语句:continue、break 和 return使用方法

Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...

L017:continue和break - 教程文案

continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...

作为前端开发者,你都经历过怎样的面试?

已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...

面试被问 const 是否不可变?这样回答才显功底

作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...

2023金九银十必看前端面试题!2w字精品!

导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。答案:CSS的盒模型是用于布局和定位元素的概念。它由内容区域...

前端面试总结_前端面试题整理

记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...

由浅入深,66条JavaScript面试知识点(七)

作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录由浅入深,66条JavaScript面试知识点(一)由浅入深,66...

2024前端面试真题之—VUE篇_前端面试题vue2020及答案

添加图片注释,不超过140字(可选)1.vue的生命周期有哪些及每个生命周期做了什么?beforeCreate是newVue()之后触发的第一个钩子,在当前阶段data、methods、com...

今年最常见的前端面试题,你会做几道?

在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...