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

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

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

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


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

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


当前回答

对于所有未标记的更改,git checkout--。

对于特定文件git checkout--路径/to/file/to/revert

其他回答

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

如果你让你的本地repo变得一团糟,那么在Git中丢弃本地提交的一个可靠方法就是。。。

使用“git-config--getremote.login.url”获取远程源的url将本地git文件夹重命名为“my_broken_local_repo”使用“gitclone<url_from_1>”获取远程git存储库的新本地副本

根据我的经验,Eclipse可以很好地处理周围的世界变化。然而,您可能需要在Eclipse中选择受影响的项目并清理它们,以迫使Eclipse重新构建它们。我想其他IDE可能也需要强制重建。

上述过程的一个副作用是,您将发现您的项目是否依赖于未放入git的本地文件。如果您发现缺少文件,那么可以将它们从“my_broken_local_repo”复制到git中。一旦您确信新的本地存储库具备所需的一切,就可以删除“my_broken_local_repo”。

您可以考虑使用带有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 reset—软HEAD~1

删除最近的提交并删除更改:

git重置--硬HEAD~1

更新时间:

您可以在此处使用新的GIT LFS:https://git-lfs.github.com/

git lfs migrate import --include="*.file_type"

然后git push