git不追踪已提交至仓库的本地又修改文件

系列文章目录


文章目录


前言

在git 中 某些文件(如配置文件) 已提交至仓库,但是本地开发需要取修改某些文件,修改完成时不想被git 记录到(因为只在本地使用),不提交至git 仓库中,那么是否有一种方式可以临时跳过这些文件呢?


一、skip-worktree命令

1.1 命令解释:

git update-index --skip-worktree 文件 ,可以让 Git 假装看不见这个文件的本地修改 → 本地随便改,永远不会被 commit /push 提交,但文件本身还在仓库里!

bash 复制代码
git update-index --skip-worktree 文件

它给文件 打了一个本地标记,告诉 Git: 我本地会修改这个文件,但这些修改只属于我自己,不要提交到 Git 仓库。效果:

  • 本地修改 → git status 看不见
  • git add . → 不会加入暂存
  • git commit → 不会被提交
  • git push → 不会推送到远程
  • 文件依然保留在仓库里,其他人不受影响

适合你的场景:

  • 文件 a 已经在仓库里
  • 本地需要修改(启动项目用)
  • 不想提交到 Git
  • 未来仓库更新时,还能正常拉取、合并、提交

1.2 和 .gitignore 的区别:

方式 作用 是否还在仓库 已提交文件是否生效
.gitignore 忽略新文件 不在 不生效
git update-index --skip-worktree 忽略已存在文件的本地修改 100% 生效

二、使用步骤:

2.1 git base 打开

在项目根目录右键-》 Open Gig Bash here -》 输入命令

c 复制代码
 find . -name "*.yml" -not -path "*/target/*" -exec git update-index --skip-worktree {} \;

结果此时 yml 文件不会被追踪到:

2.2 恢复追踪

执行以下命令

c 复制代码
 find . -name "*.yml" -not -path "*/target/*" -exec git update-index --no-skip-worktree {} \;

2.3 目录包含和排除

bash 复制代码
find . -path "*/包含目录/*" -name "*.yml" -not -path "*/排除目录1/*" -not -path "*/排除目录2/*" -exec git update-index --skip-worktree {} \;

总结

git update-index --no-skip-worktree 可以让git 不追踪 已经被提交至git 仓库,但是本地又有修改的文件。

相关推荐
我先去打把游戏先10 小时前
Ubuntu虚拟机(服务器版本)Git卸载完全教程——彻底移除与清理配置
服务器·git·单片机·嵌入式硬件·物联网·ubuntu·51单片机
不做无法实现的梦~12 小时前
Git Clone 使用 Watt/Steam++ 加速时报证书错误的原因与解决方法
大数据·git·elasticsearch
黑猫警长丶13 小时前
Git 操作笔记
笔记·git
MageGojo13 小时前
Whois 域名查询 API 接入实战:用一个 GET 请求获取域名注册信息
java·git·github
黑猫警长丶13 小时前
Git 本地操作基础
git
白狐_79814 小时前
从功能开发到开源维护:一个 Python 可视化项目的 Git 分支、维护文件与 PR 流程实践
git·python·开源
思麟呀14 小时前
git分支
git
江华森14 小时前
Git + Maven Java 项目部署实战全指南
运维·笔记·git·学习·maven
火车叼位1 天前
用脚本固化 Git Squash 合并与文件排除流程
git
wunaiqiezixin1 天前
git常用命令总结
git