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

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

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

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

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


当前回答

对于Pycharm,您可以执行Git-->Revert,然后执行pull。

其他回答

这对我来说很有用,我可以放弃实时远程服务器上的更改,并从源代码控制GitHub中提取:

git reset --hard
git pull origin master

我忽略了我的repo中的一个文件,当我执行git pull upstream master时,我得到了以下错误:

错误:您对以下文件的本地更改将被合并覆盖:myfile.js请在合并之前提交更改或将其隐藏。正在中止

为了解决这个问题,我采取了以下措施

git update-index --no-assume-unchanged myfile.js

然后我做了git状态并得到了这条消息

在分支主机上您的分支落后于“origin/master”4次提交,并且可以被快速转发。(使用“git pull”更新本地分支)未提交的更改:(使用“git add…”更新将提交什么)(使用“gitcheckout--…”放弃工作目录中的更改)修改:myfile.js未向提交添加任何更改(使用“gitadd”和/或“gitcommit-a”)

然后我执行git checkout myfile.js,然后执行git pull upstream master。这次git拉动操作成功。

如果您的存储库包含一些从master中删除的文件:

切换到主分支git获取原点git reset—硬原点/主git结帐-b newbranch

在最近的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)等。

如果你想覆盖特定的更改,你需要一些方法告诉它你想忘记哪些更改。

您可以尝试使用gitstash-patch选择性地隐藏您想要放弃的更改,然后使用gitstash drop删除该更改。然后,您可以按正常方式拉入远程更改并合并它们。