从git中的旧提交恢复文件

问题描述 投票:158回答:3

几周前我做了一个旧的提交。我想从该提交中仅恢复单个文件。我该怎么办?

git git-checkout
3个回答
193
投票
git checkout 'master@{7 days ago}' -- path/to/file.txt

这不会改变HEAD,它只会覆盖本地文件path/to/file.txt

请参阅man git-rev-parse了解可能的修订规范(当然,简单的哈希(如dd9bacb)可以很好地执行)

不要忘记提交更改(审核后......)


77
投票
  1. 通过git checkout [Revision_Key] -- path/to/file查看旧提交中的文件。
  2. 适当添加,提交,推送。

5
投票

我需要恢复最近提交到git的文件。因此,只需重申并提供另一个视角,您需要通过运行以下两个步骤来执行此操作:

  1. git log -3 这显示了最近的三个提交。阅读评论和作者姓名,以便缩小所需的确切版本。记下您想要的提交版本的长提交ID(即b6b94f2c19c456336d60b9409fb1e373036d3d71)。
  2. git checkout b6b94f2c19c456336d60b9409fb1e373036d3d71 - myfile.java 传递提交ID和要还原的文件名。确保双连字符前后有空格。

还有很多其他方法可以做到这一点。但这个是我能记住的更简单的一个。希望有所帮助。

注意:如果您在项目路径/文件夹中,则无需在checkout命令中键入完整文件的路径。


0
投票

所有答案都提到git checkout <tree-ish> -- <pathspec>。从git v2.23.0开始,有一个新的git restore方法,该方法应该承担git checkout负责的部分内容。查看github blog变化的重点。

此命令的默认行为是使用来自source参数的内容(在您的情况下将是提交哈希)恢复工作树的状态。

假设提交哈希是abcdef,命令将如下所示:

git restore --source=abcdef file_name

(默认情况下)将其放入工作树中。如果您想将更改直接放在索引中,那么可以立即提交:

git restore --source=abcdef --worktree --staged file_name

或者使用短选项名称:

git restore -s=abcdef -W -S file_name
© www.soinside.com 2019 - 2024. All rights reserved.