我不小心说了git rm -r ..我该如何从中恢复呢?

我没有承诺。

我认为所有的文件都被标记为删除,并从我的本地签出中物理删除。

编辑:我可以(如果我知道命令)恢复到上次提交。但如果我能撤销git rm -r ..因为我真的不确定我在最后一次提交之后和git rm -r之前做了什么。


当前回答

撤销git rm

git rm file             # delete file & update index
git checkout HEAD file  # restore file & index from HEAD

撤销git rm -r

git rm -r dir          # delete tracked files in dir & update index
git checkout HEAD dir  # restore file & index from HEAD

撤销git rm -rf

git rm -r dir          # delete tracked files & delete uncommitted changes
not possible           # `uncommitted changes` can not be restored.

未提交的更改包括非阶段性更改,阶段性更改但未提交。

其他回答

我也遇到过同样的情况。对我来说,解决方案是:

git checkout -- .

已经有了一些很好的答案,但我可能会建议一个很少使用的语法,它不仅工作得很好,而且非常明确地表达了您想要的东西(因此并不可怕或神秘)。

git checkout <branch>@{"20 minutes ago"} <filename>

使用Git 2.23+(2019年8月),恢复文件(和索引)的正确命令是使用…Git恢复(不是重置——很难或令人困惑的Git checkout命令)

那就是:

git restore -s=HEAD --staged --worktree -- .

或其缩写形式:

git restore -s@ -SW -- .

要重新获得一些单个文件或文件夹,可以使用以下方法

git reset -- path/to/file
git checkout -- path/to/file

这将首先重新创建路径/to/file的索引项,并重新创建上次提交时的文件,即head。

提示:可以向两个命令都传递一个提交哈希来从旧的提交中重新创建文件。详见git reset -help和git checkout -help。

如果上述方法都不能正常工作,则可以使用这里的建议检索数据:http://www.spinics.net/lists/git/msg62499.html

git prune -n
git cat-file -p <blob #>