【git】 git 删除了文件,如何找回

git 删除了文件,如何找回

  • 使用 git revert 并不是恢复误删除文件的最佳方法,因为 git revert 通常用于撤销已经提交的更改(生成一个反向提交)。如果你误删除了文件,还未提交更改,或者已经提交但想恢复删除的文件,可以按照下面的步骤操作。

情况 1:文件未提交(已删除但未提交)

如果文件被删除但你还没有进行 git commit,可以直接通过 git checkout 来恢复已删除的文件。

  • 恢复未提交的文件
cpp 复制代码
git checkout -- <文件路径>

这将从你最新的提交中恢复文件,恢复你删除的文件到删除前的状态。

  • 情况 2:文件已提交并删除
  • 如果你已经提交了删除文件的更改,你需要使用 git revert 或 git reset 来恢复删除的文件。

方法 1:使用 git checkout 找回已提交的文件

假设你删除了文件并提交了这个删除,可以通过从之前的提交恢复文件:

步骤:

查看日志,找到误删除文件之前的提交记录:

bash 复制代码
git log

从之前的提交中恢复已删除的文件(例如使用 HEAD~1,表示上一个提交):

bash 复制代码
git checkout HEAD~1 -- <文件路径>

这样可以从历史提交中恢复该文件。

方法 2:使用 git revert 来撤销删除

git revert 会生成一个新的提交来撤销之前的删除操作。

步骤:

找到删除文件的提交哈希值:

bash 复制代码
git log

使用 git revert 撤销删除文件的提交:

bash 复制代码
git revert <提交哈希>

这会生成一个新的提交,用于撤销误删除的文件。

情况 3:删除后还未 commit,但 add 了删除操作

如果你已经使用 git add 暂存了删除操作,但还没有 commit,可以使用 git reset 来撤销暂存区的更改。

步骤:

-- 取消暂存文件的删除操作

bash 复制代码
git reset HEAD <文件路径>
  • 然后,再使用 git checkout 恢复该文件:
cpp 复制代码
git checkout -- <文件路径>

通过这些方法,你可以找回被误删除的文件。如果不确定哪种方法适合你的情况,请告诉我更多细节,我可以进一步帮助你。

实操

bash 复制代码
zhangbin@LAPTOP-Y9KP MINGW64 /g/CDN/BWE-DEV/my_razor/x265_offical (master)
$ git status
On branch master
Your branch is up to date with 'origin/master'.

Changes not staged for commit:
  (use "git add/rm <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
        deleted:    build/vc17-x86_64/build-all.bat
        deleted:    build/vc17-x86_64/make-solutions.bat
        deleted:    build/vc17-x86_64/multilib.bat

no changes added to commit (use "git add" and/or "git commit -a")

zhangbin@LAPTOP-Y9KP MINGW64 /g/CDN/BWE-DEV/my_razor/x265_offical (master)
$ git checkout  build/vc17-x86_64/build-all.bat
Updated 1 path from the index

zhangbin@LAPTOP-Y9KP MINGW64 /g/CDN/BWE-DEV/my_razor/x265_offical (master)
$ git checkout  build/vc17-x86_64/make-solutions.bat
Updated 1 path from the index

zhangbin@LAPTOP-Y9KP MINGW64 /g/CDN/BWE-DEV/my_razor/x265_offical (master)
$ git checkout  build/vc17-x86_64/multilib.bat
Updated 1 path from the index

zhangbin@LAPTOP-Y9KP MINGW64 /g/CDN/BWE-DEV/my_razor/x265_offical (master)
$
相关推荐
果然_36 分钟前
为什么你的 PR 总是多出一堆奇怪的 commit?90% 的人都踩过这个 Git 坑
前端·git
yyuuuzz1 小时前
独立站搭建:从入门到避坑实战
前端·git·github
splage2 小时前
Nginx 反向代理之upstream模块以及完整配置反向代理示例
git·nginx·github
阿崽meitoufa3 小时前
hermes-agent安装到本地 Git方法
git·hermes·hermes-agent
云攀登者-望正茂6 小时前
特性分支合并develop引发的污染问题
git
就叫年华吧丶8 小时前
Git Bash、CMD 与 PowerShell 的区别详解
linux·git·命令行·powershell·cmd·gitbash
白玉cfc9 小时前
Git提交规范
git·github
电化学仪器白超1 天前
小乌龟Git全程图形化操作指南:嵌入式本地版本管理与Gitee私有云备份实战
git·python·单片机·嵌入式硬件·物联网·gitee·自动化
K3v1 天前
【git】删除本地以及远端已经合并到master的分支
大数据·git·elasticsearch
云攀登者-望正茂1 天前
将 develop 分支拉取到特性分支时解决合并污染问题
git