我如何将修改的文件转换为以前的修订,在一个特定的 commit hash (我通过 git log 和 git diff 确定)?
当前回答
要回到最后一个承诺的版本,这是最常用的,你可以使用这个更简单的命令。
git checkout HEAD file/to/restore
其他回答
你可以在四个步骤中完成:
返回整个承诺与您想要具体返回的文件 - 它将创建一个新的承诺在您的分支软重定义承诺 - 删除承诺并将变更移动到工作区域 手动点击文件返回并承诺他们下载所有其他文件在您的工作区域
您需要在终端中输入的内容:
git revert <commit_hash> git reset HEAD~1 git add <file_i_want_to_revert> && git commit -m'reverting file' git checkout.
好运
对我来说,没有一个答案看起来很清楚,所以我想添加我的,看起来很容易。
我有一个承诺 abc1 之后我做了几个(或一个修改)到一个文件 file.txt。
1.git checkout file.txt : 这将删除本地变更,如果你不需要它们
2.git checkout abc1 file.txt : 这将使您的文件到您想要的版本
3.git commit -m “Restored file.txt to version abc1” : 这将承诺您的转换。
git push : 这将把一切推到远程存储库中
在步骤2和3之间,当然,你可以做 git 状态来了解正在发生的事情。 通常你应该看到 file.txt 已经添加了,这就是为什么不需要添加 git。
您可以使用 diff 命令快速查看文件中的更改:
git diff <commit hash> <filename>
然后将特定文件转换为该承诺,使用重新设置命令:
git reset <commit hash> <filename>
您可能需要使用 --hard 选项,如果您有本地修改。
管理路点的好工作流是使用标签清晰地标记时间线中的点,我无法完全理解你的最后一句话,但你可能想要的是从前一个点分开一个分支。
git checkout <commit hash>
git checkout -b <new branch name>
然后,你可以放弃这个对你的主要线,当你准备合并这些变化:
git checkout <my branch>
git rebase master
git checkout master
git merge <my branch>
git revert <hash>
它听起来像你认为 git revert 只会影响最新的承诺。
它不会解决你的问题,如果你想转换一个更改在一个特定的文件,并承诺更改超过该文件。
这里有很多建议,主要沿着 git checkout $revision - $file 的线条。
git show $revision:$file > $file
而且,我使用这个很多只是暂时看到一个特定的版本:
git show $revision:$file
或
git show $revision:$file | vim -R -
(OBS: $ 文件需要预定为./ 如果它是 git 显示 $ 修订的相对路径: $ 文件工作)
更奇怪的是:
git archive $revision $file | tar -x0 > $file
推荐文章
- 为什么我需要显式地推一个新分支?
- 如何撤消最后的git添加?
- Rubymine:如何让Git忽略Rubymine创建的.idea文件
- Gitignore二进制文件,没有扩展名
- Git隐藏错误:Git隐藏弹出并最终与合并冲突
- 了解Git和GitHub的基础知识
- 没有。Git目录的Git克隆
- Git与Mercurial仓库的互操作性
- 忽略git中修改(但未提交)的文件?
- “git restore”命令是什么?“git restore”和“git reset”之间有什么区别?
- Git合并与强制覆盖
- Git拉另一个分支
- 在Bash命令提示符上添加git分支
- 如何更改Git日志日期格式
- git pull -rebase和git pull -ff-only之间的区别