由于一些糟糕的选择,我的本地Git存储库目前比原始库提前了五次提交,并且状态不佳。我想摆脱所有这些承诺,重新开始。

很明显,删除我的工作目录并重新克隆就可以了,但再次从GitHub下载所有内容似乎太过了,而且没有很好地利用我的时间。

也许git-restore是我需要的,但我不想在源代码之前提交10次(甚至6次),即使它确实将代码本身恢复到正确的状态。我只想假装最后半小时从未发生过。

有一个简单的命令可以做到这一点吗?这似乎是一个明显的用例,但我找不到任何例子。


请注意,这个问题专门针对提交,而不是:

未跟踪的文件未分级更改已分段但未提交的更改


当前回答

您可以考虑使用带有drop命令的交互式rebase

比如说最后三次犯罪。。。

git rebase -i HEAD~3

交换拾取命令

pick <hash1> Commit message 1
pick <hash2> Commit message 2
pick <hash3> Commit message 3

用于放置命令

drop <hash1> Commit message 1
drop <hash2> Commit message 2
drop <hash3> Commit message 3

其他回答

删除未跟踪的文件(未提交的本地更改)

git clean -df

永久删除所有本地提交并获取最新的远程提交

git reset --hard origin/<branch_name>

如果您使用的是Atlassian SourceTree应用程序,可以使用上下文菜单中的重置选项。

如果您的超额提交仅对您可见,您可以git reset--硬原点/<branch_name>移回原始位置。这将将存储库的状态重置为上一次提交,并放弃所有本地更改。

执行git还原会生成新的提交以删除旧的提交,从而使每个人的历史保持正常。

使用任意次数,恢复到上次提交,而不删除最近创建的任何文件。

git reset --soft HEAD~1

然后使用

git reset HEAD <name-of-file/files*>

拆下或解开。

您可以使用此git命令

git reset --hard origin/<branch_name>