【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)
$
相关推荐
春天姐姐2 小时前
vue3项目开发总结
前端·vue.js·git
{⌐■_■}8 小时前
【git】工作流实战:从本地仓库到远程仓库,git pull 与git rebase使用讲解,案例解析
git
大溪地C13 小时前
Git 合并冲突解决与状态分析笔记
笔记·git
CsbLanca13 小时前
Git配置个人和公司的提交信息,通过‘目录配置‘
git
娶个名字趴13 小时前
Git企业开发
git
fruge21 小时前
git上传 项目 把node_modules也上传至仓库了,在文件.gitignore 中忽略node_modules 依然不行
大数据·git·elasticsearch
_OMG_1 天前
Git 高效同步远程分支与本地分支清理技巧
git
心无旁骛~1 天前
Git笔记汇总,持续更新~
笔记·git
{⌐■_■}1 天前
【git】工作场景下的 工作区 <-> 暂存区<-> 本地仓库 命令实战 具体案例
大数据·git·elasticsearch·golang·iphone·ip·etcd
李狗蛋儿啊1 天前
zero自动化框架搭建---Git安装详解
运维·git·自动化