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

GIT,如何恢复修改过的文件,回到过去呢?

wptr33 2025-05-15 21:30 2 浏览

我们知道git系统有三个区域:工作目录、暂存区域和git仓库

所以恢复修改过的文件,需要考虑到三种情况。

第一种情况,修改了文件,之后就再也没有任何的git操作了。

这种情况只需要将当前版本的暂存区的状态还原到工作目录就行了

当前git状态:

当前文件内容:

现在我修改了testfile.txt文件,但是没有任何的git操作:

现在我向恢复修改之前的状态:

git checkout -- .\testfile.txt

执行之后,文件内容就恢复了:

第二种情况:修改了文件,并且执行了“git add",之后再没有git操作

这种情况需要先恢复目前的版本,然后再执行checkout操作:

当前git状态:

当前文件内容:

现在我修改了testfile.txt文件,并进行了git add操作:

现在我向恢复修改之前的状态:

首先我需要先恢复一下到当前git版本的暂存区状态:

git reset HEAD

然后再将目前暂存区域的文件恢复到工作目录:

git checkout -- .\testfile.txt

查看状态:

查看文件内容已经恢复:

第三种情况:修改了文件,而且执行了git add ,最后commit提交了。

这种情况下,需要将git仓库版本恢复到上一个版本,然后将暂存区域文件恢复到工作目录。

当前git状态:

当前文件内容:

现在我修改了testfile.txt文件,并进行了git add,然后执行git commit 提交到git仓库的操作:

现在我向恢复修改之前的状态:

首先因为进行了commit提交操作,所以我需要先恢复一下到上一个git版本的暂存区状态,

然后再将暂存区域的状态恢复到工作目录即可:

git reset HEAD~

git checkout -- .\testfile.txt

查看文件内容已经恢复:

总结

第二种和第三种情况,都行进了版本的回退,只是回退的版本不一样。

第二种情况没有进行提交,所以回退到当前版本就可以了,HEAD 代表当前版本的指向。

第三种情况因为进行了一次commit操作,所以版本更新了,所以需要恢复到上一个版本,HEAD~代表上一个版本。

使用”git log --oneline“可以查看提交的版本号。

执行“git reset <版本号>” 就可以回到该版本到暂存区域。

所以,需要恢复文件到什么状态,首先需要确认这个状态再哪个版本,然后恢复到这个版本,到此文件只是恢复到了暂存区域,还需要恢复工作目录的内容,所以还需要进行checkout操作。

相关推荐

如何使用git clone克隆包含子模块的仓库

技术背景在软件开发中,当项目规模逐渐增大时,为了更好地管理代码,我们常常会使用子模块将项目拆分成多个独立的部分。Git作为目前最流行的版本控制系统,提供了管理子模块的功能。但在克隆包含子模块的仓库时...

基于Docker构建安装Git/GitLab,以及制作springboot工程镜像

今天给大家分享的是《领先的开源自动化服务器Jenkins的应用实战》之基于Docker安装构建Git/GitLab版本控制与代码云存储的场所;使用Git管理项目,springboot工程制作镜像知识体...

Windows误删急救!3步找回+防删秘籍,免费工具一键恢复

“Shift+Delete一时爽,数据火葬场?”误删工作文档、清空珍贵照片、手滑格式化硬盘……这份Windows专属“后悔药”攻略,从...

Git分支创建与合并

首先,我们创建dev分支,然后切换到dev分支:12$gitcheckout-bdev...

Java项目版本控制的最佳实践

Java项目版本控制的最佳实践在Java开发的世界里,版本控制是构建高效协作和管理代码变更的基础。想象一下,如果没有版本控制,就像一群人在沙滩上画画,每个人都在修改别人的画作,很快就会变得混乱不堪。今...

10分钟搭建自己的Git仓库

10分钟搭建自己的Git仓库...

GIT,如何恢复修改过的文件,回到过去呢?

我们知道git系统有三个区域:工作目录、暂存区域和git仓库所以恢复修改过的文件,需要考虑到三种情况。第一种情况,修改了文件,之后就再也没有任何的git操作了。这种情况只需要将当前版本的暂存区的状态还...

打造企业级自动化漏洞修复系统结( GitOps + Trivy + Argo CD )

在当今DevSecOps流水线中,实现漏洞自动检测+自动修复+自动部署是关键环节。本指南将结合:...

如何搭建一个git服务器?

GitHub是一个免费托管开源代码的Git服务器,如果我们不想公开项目的源代码,又不想付费使用,那么我们可以自己搭建一台Git服务器。首先你需要一台client和一台server。client可以是w...

Python进阶-day27: 版本控制与协作

1.学习Git基本命令Git是一个强大的分布式版本控制系统,用于跟踪代码更改和团队协作。以下是课程要求的四个基本命令的说明和使用方法:(1)gitclone作用...

git 基础分支管理基础操作

两个仓库git有两个仓库,一个本地仓库,一个远端仓库。大部分开发工作都是在本地仓库完成,程序没有问题后提交到远端仓库。一般是多用户维护一个git仓库...

Git新手入门

欢迎各位准开发者与技术爱好者!如果你曾好奇专业开发者如何协作大型项目而不丢失修改记录(更不用说覆盖他人代码),那么你来对地方了。答案就是Git——已成为开发者工具库中不可或缺的利器。这份详尽指...

Git推送错误:failed to push some refs to &#39;git@gitee.com:XXX&#39;

项目推送时遇Git推送错误:error:failedtopushsomerefsto‘git@gitee.com:name/project.git’...

常用git命令-从远程更新代码合并分支、提交代码等

gitconfig设置gitconfiguser.name""...

迁移GIT仓库并带有历史提交记录

迁移git仓库开发在很多时候,会遇到一个问题。GIT仓库的管理,特别是仓库的迁移。我需要保留已有的历史记录,而不是重新开发,重头再来。...