版本控制 - git 如何还原某个文件

 有你世界就很美_484 发布于 2022-10-25 18:21

目的

想把文件 include/plugin/funclib/function_member.php 恢复到 b257f8685b71a471c4f797d05f52a1a576047ed2 (2014-12-29 23:38)这个版本,但是使用 git reset b257f8685b71a471c4f797d05f52a1a576047ed2 include/plugin/funclib/function_member.php 一直无法实现。

代码


Administrator@USER-20140115FZ /D/website/xxx.com/www (master) $ git log include/plugin/funclib/function_member.php commit bbb0a005d245e6d5ef5b1c0b1b0ef2981fa3ecb9 Author: ken Date: Mon Jan 5 22:07:37 2015 +0800 for reset commit b257f8685b71a471c4f797d05f52a1a576047ed2 Author: ken Date: Mon Dec 29 23:38:09 2014 +0800 add reg forbbiden commit 052c0233bcaef35bbf6e6ebd43bfd6a648e3d93b Author: ken Date: Mon Dec 29 21:51:44 2014 +0800 add coname filter for register commit 53298e00de944863f6092d0d4c0a260d00124f9f Author: ken Date: Mon Dec 29 01:24:13 2014 +0800 add referrals.php delete some php files like serv.php yqm.php,modify registe commit 44118e5256eb9786d024f9b7d2dfb8af0bd8a308 Author: default7 Date: Sun Jul 27 17:05:21 2014 +0800 first commit Administrator@USER-20140115FZ /D/website/xxx.com/www (master) $ git reset b257f8685b71a471c4f797d05f52a1a576047ed2 include/plugin/funclib/fun ction_member.php --hard fatal: Cannot do hard reset with paths. Administrator@USER-20140115FZ /D/website/xxx.com/www (master) $ git reset b257f8685b71a471c4f797d05f52a1a576047ed2 include/plugin/funclib/fun ction_member.php Unstaged changes after reset: M include/plugin/funclib/function_member.php Administrator@USER-20140115FZ /D/website/xxx.com/www (master) $
6 个回答
  • git checkout <sha1-of-a-commit> </path/to/your/file>

    2022-10-27 00:17 回答
  • 1.如果你的提交还没有分享发布到远端可以用git rebase -i origin/branch 来对相应分支进行edit修改后重新提交git commit --ammend。
    2,如果你的提交已经分享到远端只能通过git revert 相应分支的情况,然后将其他文件checkout,只保留这个修改,然后再提交。
    3.有点复杂,如果有gui工具就很方便了,我一般是在webstrom的git控制上,点击某个版本的某个文件右击revert再提交即可

    2022-10-27 00:17 回答
  • 我觉得使用tortoisegit挺好的啊,配置好之后直接有图形界面,用rever就可以恢复以前版本了

    2022-10-27 00:17 回答
  • git不能把单独的某个文件恢复到指定的版本,如果要这要做,可以这样
    1、git reset 版本号,这时候,会产生一个和版本号对应的分支
    2、git checkout到这个分支,把要恢复的文件拷贝走
    3、git checkout到原来的分支,把文件再拷贝回来,覆盖掉现在的文件,然后git add,git commit

    2022-10-27 00:17 回答
  • 还需要执行git checkout xxxxx(文件名)

    2022-10-27 00:30 回答
  • 直接用 git-checkout 即可。理解起来稍微有点奇怪就是了。

    $ git checkout ${commit} /path/to/file
    

    来源参考:

    2022-10-27 00:30 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有