【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

相关推荐
深海鱼在掘金3 天前
Git 完全指南 —— 第1章:Git 概览与版本控制演进
git
noravinsc3 天前
关于Git Flow
git
蜜獾云3 天前
在Git中配置用户名和密码
git
scx_link4 天前
通过git bash在本地创建分支,并推送到远程仓库中
开发语言·git·bash
南大白4 天前
IntelliJ IDEA 运行时的 JVM 本地内存溢出崩溃
git
码农小旋风4 天前
Claude Code 基础用法大全:对话、分析、修改、测试、Git 和工作流
人工智能·git·chatgpt·claude
南大白4 天前
Git 撤回提交完整方案
git
像风一样的男人@4 天前
python --实现代理服务器
git·ui
sbjdhjd4 天前
从零搭建企业级 CI/CD(下):Jenkins+GitLab+Harbor 全链路实战指南
git·servlet·ci/cd·云原生·云计算·gitlab·jenkins
码云数智-大飞4 天前
Go Channel 详解:并发通信的正确姿势
前端·数据库·git