在我的一个开发分支中,我对代码库做了一些更改。在我能够完成正在开发的功能之前,我必须将当前分支切换到master来演示一些功能。但仅仅使用“git checkout master”就保留了我在开发分支中所做的更改,从而破坏了master中的一些功能。因此,我所做的是在我的开发分支上提交一条提交消息“临时提交”,然后为演示签出主控。
现在,我已经完成了演示并返回到我的开发分支中,我想删除我所做的“临时提交”,同时仍然保留我所作的更改。这可能吗?
在我的一个开发分支中,我对代码库做了一些更改。在我能够完成正在开发的功能之前,我必须将当前分支切换到master来演示一些功能。但仅仅使用“git checkout master”就保留了我在开发分支中所做的更改,从而破坏了master中的一些功能。因此,我所做的是在我的开发分支上提交一条提交消息“临时提交”,然后为演示签出主控。
现在,我已经完成了演示并返回到我的开发分支中,我想删除我所做的“临时提交”,同时仍然保留我所作的更改。这可能吗?
当前回答
还有一种方法。
在临时提交的顶部添加提交,然后执行以下操作:
git rebase -i
要将两个提交合并为一个(命令将打开带有显式指令的文本文件,请对其进行编辑)。
其他回答
在某些情况下,我只想在第一次提交时撤消对特定文件的更改,以便将它们添加到第二次提交中,并有一个更干净的git日志。
在这种情况下,我要做的是:
git checkout HEAD~1 <path_to_file_to_put_in_different_commit>
git add -u
git commit --amend --no-edit
git checkout HEAD@{1} <path_to_file_to_put_in_different_commit>
git commit -m "This is the new commit"
当然,即使在使用committosplit上的编辑选项进行rebase-i时,这也能很好地工作。
2020简单方法:
git reset <commit_hash>
(您要保留的最后一次提交的提交哈希)。
如果推送提交,则可以执行以下操作:
git push -f
您将在本地保留当前未提交的更改
您正在查找git reset HEAD^--soft或git reset-HEAD^-mixed。
如文档中所述,重置命令有三种模式:
git reset HEAD^--软
撤消git提交。更改仍然存在于工作树(项目文件夹)+索引(--cached)中
git reset HEAD^--混合
撤消gitcommit+gitadd。工作树中仍存在更改
git reset HEAD^--硬
就像你从未对代码库做过这些更改一样。更改将从工作树中删除。
首先,您可以使用以下命令查看日志-
git reflog
这将显示所有提交,然后找出要撤消的提交以及与之关联的头号,然后输入以下命令
git reset HEAD@{#NumberOfCommitYouWantToUndo}
例如git reset HEAD@{3}
git-resetHEAD@{#}显示重置后的所有未分级更改
对于使用zsh的用户,您必须使用以下选项:
git reset—软头\^
此处解释:https://github.com/robbyrussell/oh-my-zsh/issues/449
如果URL失效,重要的部分是:
转义命令中的^你也可以选择使用HEAD~,这样你就不必每次都逃避它。