假设我在Git存储库中。我删除一个文件并提交更改。我继续工作,并做出更多承诺。然后,我发现删除该文件后需要恢复该文件。

我知道我可以使用gitcheckout<commit>--filename.txt签出文件,但我不知道该文件何时被删除。

如何查找删除给定文件名的提交?如何将该文件恢复到工作副本中?


当前回答

为了使用Git恢复所有删除的文件,您还可以执行以下操作:

git checkout $(git ls-files --deleted)

其中git-ls-files-deleted列出了所有删除的文件,gitcheckout$(git命令)在参数中恢复文件列表。

其他回答

如果删除了最新HEAD提交中存在的文件,则可以使用以下方法恢复该文件:

git checkout HEAD -- path/to/file.ext

查找影响给定路径的最后一次提交。由于该文件不在HEAD提交中,因此前一次提交必须已将其删除。

git rev-list -n 1 HEAD -- <file_path>

然后在提交之前使用插入符号(^)签出版本:

git checkout <deleting_commit>^ -- <file_path>

或者在一个命令中,如果$file是有问题的文件。

git checkout $(git rev-list -n 1 HEAD -- "$file")^ -- "$file"

如果使用zsh并启用EXTENDED_GLOB选项,则插入符号将不起作用。您可以改用~1。

git checkout $(git rev-list -n 1 HEAD -- "$file")~1 -- "$file"

实际上,这个问题直接与Git有关,但像我这样的人除了了解Git CLI命令之外,还使用诸如WebStorm VCS之类的GUI工具。

我右键单击包含已删除文件的路径,然后转到Git,然后单击Show History。

VCS工具显示了所有的修订序列,我可以看到它们的所有提交和更改。

然后我选择我的朋友删除PostAd.js文件的提交。现在参见下文:

现在,我可以看到我希望删除的文件。我只需双击文件名,它就会恢复。

我知道我的答案不是Git命令,但对于初学者和专业开发人员来说,它是快速、可靠和容易的。WebStorm VCS工具非常棒,非常适合使用Git,而且不需要任何其他插件或工具。

如果你只做了更改并删除了一个文件,但没有提交它,而现在你放弃了你的更改

git checkout -- .

但是删除的文件没有返回,只需执行以下命令:

git checkout <file_path>

很快,你的文件回来了。

如果您知道删除文件的提交,请运行以下命令:

git diff --diff-filter=D --name-only <SHA1_deletion>~1 <SHA1_deletion> | xargs git checkout <SHA1_deletion>~1 --

管道之前的部分列出了提交中删除的所有文件;它们都是从上一次提交中签出以恢复它们。