假设我在Git存储库中。我删除一个文件并提交更改。我继续工作,并做出更多承诺。然后,我发现删除该文件后需要恢复该文件。
我知道我可以使用gitcheckout<commit>--filename.txt签出文件,但我不知道该文件何时被删除。
如何查找删除给定文件名的提交?如何将该文件恢复到工作副本中?
假设我在Git存储库中。我删除一个文件并提交更改。我继续工作,并做出更多承诺。然后,我发现删除该文件后需要恢复该文件。
我知道我可以使用gitcheckout<commit>--filename.txt签出文件,但我不知道该文件何时被删除。
如何查找删除给定文件名的提交?如何将该文件恢复到工作副本中?
当前回答
我也有同样的问题。在不知情的情况下,我创建了一个悬空的承诺。
列出悬空提交
git fsck—找到丢失
检查每个悬空提交
git reset--hard<commit id>
当我移动到悬空提交时,我的文件再次出现。
git状态,原因如下:
“HEAD从<commit id where it detached>分离”
其他回答
简单而精确-
首先,获取一个最新的稳定提交,其中您可以通过-
git log
假设您找到$commitid 1234567…,然后
git checkout <$commitid> $fileName
这将还原该提交中的文件版本。
如果你只做了更改并删除了一个文件,但没有提交它,而现在你放弃了你的更改
git checkout -- .
但是删除的文件没有返回,只需执行以下命令:
git checkout <file_path>
很快,你的文件回来了。
git checkout /path/to/deleted.file
使用以下代码将以前的文件检索到本地目录时,我也遇到了这个问题:
git checkout <file path with name>
下面的例子对我很有用:
git checkout resources/views/usaSchools.blade.php
我也有同样的问题。在不知情的情况下,我创建了一个悬空的承诺。
列出悬空提交
git fsck—找到丢失
检查每个悬空提交
git reset--hard<commit id>
当我移动到悬空提交时,我的文件再次出现。
git状态,原因如下:
“HEAD从<commit id where it detached>分离”