如何忽略Git pull上的以下错误消息?
您对以下文件的本地更改将被合并覆盖
如果我想覆盖它们怎么办?
我试过像git pull-f这样的方法,但没有任何效果。
要明确的是,我只想覆盖特定的更改,而不是所有更改。
如何忽略Git pull上的以下错误消息?
您对以下文件的本地更改将被合并覆盖
如果我想覆盖它们怎么办?
我试过像git pull-f这样的方法,但没有任何效果。
要明确的是,我只想覆盖特定的更改,而不是所有更改。
当前回答
如果要在服务器上保留生产更改,只需合并到新的配置项中即可。处理方法如下:
git stash
git pull
git stash pop
也许你没有执行所有操作。你可以知道下一步可以做什么。
其他回答
如果要放弃对一个文件的本地更改,可以执行以下操作:
git checkout -- <file>
然后,您可以使用最新版本覆盖文件,只需执行以下操作:
git pull
如果您的存储库包含一些从master中删除的文件:
切换到主分支git获取原点git reset—硬原点/主git结帐-b newbranch
我忽略了我的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拉动操作成功。
我有一个特殊的情况:我有个文件--假设它没有改变。很难找到,因为gitstatus命令没有显示任何更改
如果您想从工作副本中删除所有本地更改(包括未被git跟踪的文件),只需将其隐藏:
git stash push --include-untracked
如果你不再需要它们,你现在可以放下这些东西:
git stash drop
如果您不想隐藏已经暂存的更改(例如使用gitadd),那么添加选项--keep-index。然而,请注意,如果这些阶段性的更改与上游的更改发生冲突,这仍然会阻止合并。
如果您只想覆盖本地更改的特定部分,有两种可能:
提交您不想覆盖的所有内容,其余部分使用上面的方法。对于要覆盖的更改,请使用git checkout path/to/file/to/revert。确保文件未通过git reset HEAD path/to/file/to/revert暂存。