我使用了git pull并发生了合并冲突:

unmerged:   some_file.txt

You are in the middle of a conflicted merge.

如何放弃对文件所做的更改,只保留已提取的更改?


当前回答

由于您的拉动不成功,那么HEAD(而不是HEAD^)是分支上最后一个“有效”提交:

git reset --hard HEAD

你想要的另一件事是让他们的改变凌驾于你的改变之上。

旧版本的git允许您使用“他们的”合并策略:

git pull --strategy=theirs remote_branch

但正如Junio Hamano(Git维护者)在这条消息中所解释的那样,这条消息已经被删除。如链接中所述,您可以这样做:

git fetch origin
git reset --hard origin

其他回答

如果最终出现合并冲突,并且没有任何要提交的内容,但仍显示合并错误。在应用所有下面提到的命令之后,

git reset --hard HEAD
git pull --strategy=theirs remote_branch
git fetch origin
git reset --hard origin

请删除

.git\index.lock

文件[恢复时剪切粘贴到其他位置],然后根据需要的版本输入以下任意命令。

git reset --hard HEAD
git reset --hard origin

希望这有帮助!!!

由于您的拉动不成功,那么HEAD(而不是HEAD^)是分支上最后一个“有效”提交:

git reset --hard HEAD

你想要的另一件事是让他们的改变凌驾于你的改变之上。

旧版本的git允许您使用“他们的”合并策略:

git pull --strategy=theirs remote_branch

但正如Junio Hamano(Git维护者)在这条消息中所解释的那样,这条消息已经被删除。如链接中所述,您可以这样做:

git fetch origin
git reset --hard origin

如果您的git版本>=1.6.1,则可以使用git reset-merge。

此外,正如@Michael Johnson所提到的,如果您的git版本是>=1.7.4,您也可以使用gitmerge--abort。

一如既往,在开始合并之前,确保没有未提交的更改。

从gitmerge手册页

当存在merge_HEAD时,gitmerge--abort等同于gitreset-merge。

合并过程中,MERGE_HEAD出现。

此外,关于启动合并时未提交的更改:

如果在开始合并之前有不想提交的更改,只需在合并之前将其保存,并在完成合并或中止合并后将其弹出。

可能不是OP想要的,但对我来说,我试图将一个稳定分支合并到一个功能分支,但冲突太多了。由于HEAD被多次提交更改,所以我没有成功重置更改,所以简单的解决方案是强制签出到一个稳定的分支。然后您可以签出到另一个分支,它将与合并前一样。

git checkout-f master

git结帐侧分支

对于git>=1.6.1:

git merge --abort

对于旧版本的git,这将完成以下任务:

git reset --merge

or

git reset --hard