有没有办法恢复或撤销git拉,使我的源/回购将回到做git拉之前的旧状态? 我想这样做是因为它合并了一些我不想这样做的文件,但只合并了其他剩余的文件。我想拿回那些文件,可以吗?

编辑:我想撤销git合并澄清。 看到一些答案后,我这样做了

git reflog
bb3139b... HEAD@{0}: pull : Fast forward
01b34fa... HEAD@{1}: clone: from ...name...

现在,我该怎么办?做git重置——难吗?我不想再搞砸了,所以问详细步骤?


当前回答

要将最后的合并恢复到自定义分支,最简单的方法是:

git reset --hard custom-branch@{1}

主分支示例:

git reset --hard main@{1}

其他回答

这是恢复拉取更改的最简单方法。

** Warning **

请备份您更改的文件,因为它将删除新创建的文件和文件夹。

git reset --hard 9573e3e0

其中9573e3e0是你的{提交id}

运行git pull执行以下任务,顺序如下:

git fetch git 合并

合并步骤将在配置中合并已设置的分支。您想撤消合并步骤,但可能不撤消取回(没有多大意义,也不应该是必要的)。

要撤消合并,使用git reset—很难将本地存储库重置到以前的状态;使用git-reflog找到之前状态的SHA-1,然后重置到它。

警告

本节中列出的命令删除所有未提交的更改,可能会导致工作丢失:

git reset --hard

或者,重置到一个特定的时间点,例如:

git reset --hard master@{"10 minutes ago"}

这样做取消你的合并操作:git merge——abort。

如果有一个失败的合并,这是最常见的原因,想要撤销一个git拉,运行git reset——merge完全是人们所期望的:保留获取的文件,但撤销的合并,git拉试图合并。然后,你可以决定如何做,而不是git合并有时产生的混乱。它不需要找到确切的提交ID,这在其他答案中很难提到。

如果你刚刚在本地拉了一个分支,想要从本地工作区中删除由'git pull'或'git merge'命令引起的更改,那么只需做一个git重置——很难

此命令将从本地工作区中删除所有未提交的更改,并且无法撤消。所以一定要备份你尚未提交的重要工作。