如何将文件还原到以前的提交,但将其他文件保留到最新提交

时间:2017-08-16 13:00:36

标签: git

假设我有这些提交(字母是哈希数):

-a(initial commit)
-b(implemented feature request affected foo.php and bar.php)
-c(someone else's commit)
-d(someone experimented on foo.php/bar.php and forgot to discard changes)
-e(another commit)
-f(latest commit)

如何将foo.php和bar.php更改为提交“c”期间的内容。 到目前为止,我已经尝试了git reset cgit reset --hard c,但它改变了整个存储库。

到目前为止,我尝试的另一种方法是制作另一个repo和reset --hard c的克隆,然后我手动将粘贴的foo.php和bar.php复制到我的工作副本然后我上演并将更改推送到远程。

1 个答案:

答案 0 :(得分:2)

只需将文件还原为旧提交,然后提交更改。

git checkout <old_commit_id> file_path

例如 -

git checkout <hash_of_c> foo.php
git checkout <hash_of_c> bar.php
git add -u
git commit -m "revert foo and boo"