【Git】git拉取远端但是本地存在不想提交文件处理

项目场景:

提示:这里简述项目相关背景:

我本地修改了20个文件,新增了10个文件。一共30个修改文件

由于项目周期导致,我提交git只需要提交指定的5个文件(这里提交的就会被追踪,所以不需要判断是否为新增文件)

如图所示,编辑器显示更改


问题描述

提示:这里描述项目中遇到的问题:

假设上述30个修改点,我提交了8个文件到分支,已经推送到远端了。

这8个文件就是一期修改模块,但是出现了一个地方,就是我的同事,修改了其中某个文件的代码,并且推送了(这是假设场景)

此时:远端有一个新的提交记录,但是我本地有一大堆更改文件

1、我要拉取远端代码合并到本地

2、我本地代码不想提交commit,但是我暂存也不能拉取下来

豆包给的答案

操作阶段 「暂存的更改」 「更改」列表 能否 pull
操作前(你现在) Subscribing.vue 21 个文件(红框) ❌ 不能(有本地修改)
执行 git stash --keep-index 后 Subscribing.vue(保留) 空(21 个被藏起来) ✅ 可以
执行 git stash pop 后 Subscribing.vue(保留) 21 个文件(完全恢复) ❌ 回到初始状态

已暂存的 → 还在

未暂存的 → 藏起来

工作区变干净 ✅

c 复制代码
暂存更改(保留已暂存)
git stash --keep-index

恢复刚才藏起来的文件
git stash pop

控制台显示红色


分析:

会出现一个情况

命令行处理的对象不一样

执行后还存在一些文件

你现在看到的 "还在更改里的文件",一定是这两种:

  1. 新增的文件(你本地新建的,从来没提交过的)
  2. 从来没有被 git add 过的文件
    它们叫 untracked filesgit stash 默认不会动它们!所以你执行 git stash --keep-index 后,它们依然留在更改列表,导致你还是不能 pull!

你只需要把命令改成这个(多一个 -u)

bash 复制代码
git stash --keep-index -u
这个 -u 就是:
把 "未跟踪的新文件" 也一起藏起来!
  • git stash --keep-index
    → 只藏 已修改过的旧文件
    → 不藏 新增文件
  • git stash --keep-index -u
    → 藏 所有修改 + 所有新增文件
    → 工作区 100% 变干净
    → 就能 pull 了

总结:

bash 复制代码
# 一步:把所有东西全部藏起来(包含暂存的、未暂存的、新增文件)
git stash push -u -m "temp"

# 二步:拉代码(现在 100% 成功)
git pull

# 三步:恢复所有
git stash pop

相关推荐
LIO1 小时前
前端开发之Git 代码仓库管理详细教程
前端·git
大山同学1 小时前
DeepSeek-TUI:1M 上下文、递归子代理与 Git 沙箱回滚
git
HoneyMoose3 小时前
执行 git svn clone --stdlayout 命令无输出
git·svn
HoneyMoose4 小时前
把 SVN 仓库转换为 Git 需要的 2 个命令
git·svn
历程里程碑14 小时前
4 Git远程协作:从零开始,玩转仓库关联与代码同步(带实操代码讲解)
大数据·c++·git·elasticsearch·搜索引擎·gitee·github
金銀銅鐵17 小时前
[git] 浅解 git reset 命令
git·后端
zhangfeng113317 小时前
部署到服务器上 宝塔系统 使用宝塔在线编辑器 FTP 批量上传 Git 部署 打包上传 codebudyy 编程程序开发
服务器·git·编辑器
学习是种信仰18 小时前
Git工作流
git·深度学习
yuanyuan2o220 小时前
Git merge 的几种不同模式
git·github
视觉小萌新20 小时前
关于Vscode配置企业Git
git