git status中显示为 deleted 状态的如何回退,不再为deleted状态

git status 中显示为 deleted: 的文件,表示这些文件已从工作区中删除,但 Git 仍在跟踪它们。以下是几种方式来回退这种状态,使 deleted: 不再显示:


1. 恢复已删除的文件到工作区

如果希望恢复被删除的文件,可以从 Git 历史中将它们恢复出来:

bash 复制代码
git checkout HEAD -- <file_name>

或者恢复所有被删除的文件:

bash 复制代码
git checkout HEAD -- .
结果

这将从当前分支的最后一次提交中恢复被删除的文件到工作目录,git status 中的 deleted: 不再显示。


2. 停止 Git 跟踪这些文件

如果不需要恢复这些文件,但希望删除文件的状态不再显示,可以让 Git 停止跟踪这些文件:

bash 复制代码
git rm --cached <file_name>

或者一次性移除所有被删除的文件:

bash 复制代码
git rm --cached $(git ls-files --deleted)
结果

这会让 Git 停止跟踪这些文件,但不会删除工作目录中的其他文件。随后 git status 中将不再显示 deleted: 状态。


3. 将删除的更改提交到 Git

如果文件确实是被删除的,并且希望将删除操作记录到 Git 中,可以直接提交删除:

bash 复制代码
git add -u
git commit -m "Remove deleted files"
结果

git status 中的 deleted: 文件会变成 nothing to commit, working tree clean


总结:

  • 如果要恢复文件,使用 方法 1
  • 如果要停止 Git 跟踪文件,使用 方法 2
  • 如果确认文件已删除并提交,使用 方法 3

选择适合您需求的方法执行即可!

相关推荐
whale fall3 小时前
git add、git commit、git push 的区别和联系
git
倾云鹤3 小时前
Git同时推送多个远程仓库
git
sdm0704277 小时前
基础开发工具git,gdb
git
胡琦博客10 小时前
如何同步远程分支到本地(远程有些分支已经删除了)
git
AI成长日志13 小时前
【实用工具教程】Git进阶:分支策略与合并冲突解决
git
ruanCat14 小时前
加了 .gitattributes 就万事大吉?我差点毁了整个团队的 Git 工作流
git
咋吃都不胖lyh14 小时前
查看 Git 本地仓库关联的远程仓库链接(URL)
git
wheelmouse778814 小时前
AI 时代的 Git 进阶术:如何优雅地让多个 Agent 并行开发
人工智能·git·ai编程
如意.7591 天前
【Linux开发工具实战】Git、GDB与CGDB从入门到精通
linux·运维·git
用户9186861286871 天前
Git 版本控制完全指南:从入门到精通
git