git 删除了文件,如何找回
- 使用 git revert 并不是恢复误删除文件的最佳方法,因为 git revert 通常用于撤销已经提交的更改(生成一个反向提交)。如果你误删除了文件,还未提交更改,或者已经提交但想恢复删除的文件,可以按照下面的步骤操作。
情况 1:文件未提交(已删除但未提交)
如果文件被删除但你还没有进行 git commit,可以直接通过 git checkout 来恢复已删除的文件。
- 恢复未提交的文件
git checkout -- <文件路径>
这将从你最新的提交中恢复文件,恢复你删除的文件到删除前的状态。
- 情况 2:文件已提交并删除
- 如果你已经提交了删除文件的更改,你需要使用 git revert 或 git reset 来恢复删除的文件。
方法 1:使用 git checkout 找回已提交的文件
假设你删除了文件并提交了这个删除,可以通过从之前的提交恢复文件:
步骤:
查看日志,找到误删除文件之前的提交记录:
git log
从之前的提交中恢复已删除的文件(例如使用 HEAD~1,表示上一个提交):
git checkout HEAD~1 -- <文件路径>
这样可以从历史提交中恢复该文件。
方法 2:使用 git revert 来撤销删除
git revert 会生成一个新的提交来撤销之前的删除操作。
步骤:
找到删除文件的提交哈希值:
git log
使用 git revert 撤销删除文件的提交:
git revert <提交哈希>
这会生成一个新的提交,用于撤销误删除的文件。
情况 3:删除后还未 commit,但 add 了删除操作
如果你已经使用 git add 暂存了删除操作,但还没有 commit,可以使用 git reset 来撤销暂存区的更改。
步骤:
– 取消暂存文件的删除操作
git reset HEAD <文件路径>
- 然后,再使用 git checkout 恢复该文件:
git checkout -- <文件路径>
通过这些方法,你可以找回被误删除的文件。如果不确定哪种方法适合你的情况,请告诉我更多细节,我可以进一步帮助你。
实操
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)
$