假设我在一个Git仓库中。我删除了一个文件并提交了更改。我继续工作并进行一些更多的提交。然后,我发现在删除该文件后需要恢复它。
我知道可以使用git checkout <commit> -- filename.txt
来检出一个文件,但我不知道该怎么找到删除了给定文件名的提交。
- 如何找到删除了给定文件名的提交?
- 如何将该文件恢复到我的工作副本中?
找到影响给定路径的最后一个提交。由于文件不在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,file,删除,仓库,--,查找,提交,git
From: https://www.cnblogs.com/xiaomandujia/p/17796489.html