问题描述
目的想把文件 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.phpcommit bbb0a005d245e6d5ef5b1c0b1b0ef2981fa3ecb9Author: ken <xxx@gmail.com>Date: Mon Jan 5 22:07:37 2015 +0800 for resetcommit b257f8685b71a471c4f797d05f52a1a576047ed2Author: ken <xxx@gmail.com>Date: Mon Dec 29 23:38:09 2014 +0800 add reg forbbidencommit 052c0233bcaef35bbf6e6ebd43bfd6a648e3d93bAuthor: ken <xxx@gmail.com>Date: Mon Dec 29 21:51:44 2014 +0800 add coname filter for registercommit 53298e00de944863f6092d0d4c0a260d00124f9fAuthor: ken <xxx@gmail.com>Date: Mon Dec 29 01:24:13 2014 +0800 add referrals.php delete some php files like serv.php yqm.php,modify registecommit 44118e5256eb9786d024f9b7d2dfb8af0bd8a308Author: default7 <xxx@gmail.com>Date: Sun Jul 27 17:05:21 2014 +0800 first commitAdministrator@USER-20140115FZ /D/website/xxx.com/www (master)$ git reset b257f8685b71a471c4f797d05f52a1a576047ed2 include/plugin/funclib/function_member.php --hardfatal: Cannot do hard reset with paths.Administrator@USER-20140115FZ /D/website/xxx.com/www (master)$ git reset b257f8685b71a471c4f797d05f52a1a576047ed2 include/plugin/funclib/function_member.phpUnstaged changes after reset:M include/plugin/funclib/function_member.phpAdministrator@USER-20140115FZ /D/website/xxx.com/www (master)$
问题解答
回答1:直接用 git-checkout 即可。理解起来稍微有点奇怪就是了。
$ git checkout ${commit} /path/to/file
来源参考:
http://stackoverflow.com/questions/215718/reset-or-revert-a-specific-file-to-a-specific-revision-using-githttps://www.kernel.org/pub/software/scm/git/docs/git-checkout.html回答2:还需要执行git checkout xxxxx(文件名)
回答3:git不能把单独的某个文件恢复到指定的版本,如果要这要做,可以这样1、git reset 版本号,这时候,会产生一个和版本号对应的分支2、git checkout到这个分支,把要恢复的文件拷贝走3、git checkout到原来的分支,把文件再拷贝回来,覆盖掉现在的文件,然后git add,git commit
回答4:我觉得使用tortoisegit挺好的啊,配置好之后直接有图形界面,用rever就可以恢复以前版本了
回答5:1.如果你的提交还没有分享发布到远端可以用git rebase -i origin/branch 来对相应分支进行edit修改后重新提交git commit --ammend。2,如果你的提交已经分享到远端只能通过git revert 相应分支的情况,然后将其他文件checkout,只保留这个修改,然后再提交。3.有点复杂,如果有gui工具就很方便了,我一般是在webstrom的git控制上,点击某个版本的某个文件右击revert再提交即可
回答6:git checkout <sha1-of-a-commit> </path/to/your/file>