【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)
$
相关推荐
我是李武涯1 小时前
如何修改git的commit消息
git
fruge2 小时前
Git 进阶技巧:分支管理、冲突解决、提交规范实操
大数据·git·elasticsearch
spencer_tseng2 小时前
Git-2.18.0-64-bit.exe client install
git
摇滚侠4 小时前
Idea Git 合并分支,rebase 和 merge 的区别,应该使用哪个,多人协作开发,禁止使用 rebase 合并分支
git·github
winfreedoms5 小时前
将 Git 恢复到「上一次提交(git commit)的版本」操作
git
系夏普5 小时前
Git 的三大工作区域:工作区、暂存区、本地仓库
git
摇滚侠7 小时前
零基础小白自学 Git_Github 教程,分支合并,笔记13
笔记·git·github
young7 小时前
Git分支回退到指定提交点
git
悟能不能悟7 小时前
在TypeScript中 const xxx=(xx:any)=>{}为什么要加any
linux·git·typescript
系夏普7 小时前
重新学习 Git:从版本控制系统说起
git