如何忽略Git pull上的以下错误消息?

您对以下文件的本地更改将被合并覆盖

如果我想覆盖它们怎么办?

我试过像git pull-f这样的方法,但没有任何效果。

要明确的是,我只想覆盖特定的更改,而不是所有更改。


当前回答

在最近的Git中,您可以添加-r/--rebase on pull命令,以在提取后将当前分支重新置于上游分支之上。警告应该会消失,但有可能会出现一些需要解决的冲突。


或者,您可以强制检查不同的分支,然后再次返回主分支,例如:

git checkout origin/master -f
git checkout master -f

然后像往常一样再次拉动:

git pull origin master

使用此方法可以节省时间,避免隐藏(git stash)和潜在的权限问题、重新设置文件(git reset HEAD--hard)、删除文件(gitclean-fd)等。

其他回答

我有一个特殊的情况:我有个文件--假设它没有改变。很难找到,因为gitstatus命令没有显示任何更改

这适用于我覆盖所有本地更改,并且不需要标识:

git reset --hard
git pull

对我来说,这是有效的:-

首先,我清理了所有未跟踪的文件,运行->gitclean-f。数字拉力

这是我解决问题的策略。

问题陈述

我们需要对10多个文件进行更改。我们尝试了PULL(git PULL origin master),但git喊道:

错误:您对以下文件的本地更改将被覆盖通过合并:请先提交更改或将其隐藏合并

我们尝试执行commit,然后执行pull,但它们也不起作用。

解决方案

实际上,我们处于肮脏的阶段,因为这些文件位于“暂存区”,也就是“索引区”,有些文件位于“头部区”,即“本地Git目录”。我们想从服务器中提取更改。

查看此链接,以明确方式获取有关Git不同阶段的信息:Git阶段

我们遵循以下步骤

git stash(这使我们的工作目录变得干净。您的更改通过git存储在堆栈中)。git pull-origin master(从服务器中拉取更改)git stash apply(应用堆栈中的所有更改)gitcommit-m“message”(已提交更改)git推送原始主机(将更改推送到服务器)git stash drop(删除堆栈)

让我们了解您何时以及为什么需要隐藏

如果您处于脏状态,则意味着您正在对文件进行更改,然后由于任何原因,您被迫拉入或切换到另一个分支以进行一些非常紧急的工作,因此此时,在提交更改之前,您无法拉入或转换。隐藏命令在这里作为帮助。

摘自ProGIT,第2版:

通常,当你在项目的一部分工作时一个混乱的状态,你需要切换分支来处理其他东西。问题是,你不想完成了一半的工作,这样你就可以稍后回到这一点。这个这个问题的答案是gitstash命令。Stashing需要工作目录的脏状态–即修改后的跟踪文件和暂存更改–并将其保存在未完成的堆栈中您可以随时重新应用的更改。

试试这个

git fetch --all 

git reset --hard origin/master

git pull origin master

对我来说,用力拉