当前位置: 首页 > article >正文

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

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)
$


http://www.kler.cn/a/370792.html

相关文章:

  • 【MySQL】数据库约束和多表查询
  • minio https配置
  • 交直流混合微电网多台互联变换器并联
  • 意图颠覆电影行业的视频生成模型:Runway的Gen系列
  • 28:CAN总线入门一:CAN的基本介绍
  • GraphRAG如何使用ollama提供的llm model 和Embedding model服务构建本地知识库
  • java中Scanner的nextLine和next方法
  • 地图讲故事之GIS遇到历史-中国十大古都篇
  • Linux 开机自动挂载硬盘
  • ThinkPHP+Mysql 灵活用工+灵活用工平台+灵活用工系统
  • 大数据新视界 -- 大数据大厂之大数据重塑影视娱乐产业的未来(4 - 4)
  • MySQL 数据库备份与恢复全攻略
  • 详解PHP正则表达式中的转义操作
  • SQL 与 MY SQL
  • Python实现基于WebSocket的stomp协议调试助手工具
  • 《MYSQL实战45讲》表数据删一半,为什么表文件大小不变?
  • 算法题解记录32+++最长连续序列(百题筑基)
  • 【专题】计算机网络之数据链路层
  • 【数据结构和算法】二、python中的常用数据结构(数组、链表、堆栈、递归、二叉树、哈夫曼树等数据结构的基本原理讲解与实战演练)
  • PyTorch中Transformer 模型介绍
  • 【Linux系统编程】线程深入运用
  • K-fold交叉验证后如何确认最终模型权重
  • 通过异地组网工具+RustDesk实现虚拟局域网使用远程桌面RDP
  • android源码 system目录下 android源码目录结构
  • Microsoft Office PowerPoint制作科研论文用图
  • vue Element U 解决表格数据不更新问题