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 仓库,但是本地又有修改的文件。

相关推荐
嘻嘻仙人4 天前
Ubuntu中 git上传自己的项目和二次上传一般流程
git·github
Patrick_Wilson4 天前
Squash Merge 的血缘陷阱:为什么删掉的代码又活了过来
前端·git·程序员
沉浸学习的匿名网友4 天前
什么是 .gitignore?为什么每个 Git 项目几乎都离不开它?
前端·git
深海鱼在掘金5 天前
Git 完全指南 —— 第3章:理解工作区、暂存区、版本库三个核心
git
江华森5 天前
Git 基础筑基:从原理到团队协作的全栈实战
git
JakeJiang5 天前
Git 必备命令指南:从日常高频到项目开发实战
git
叫我少年6 天前
Windows 中安装 git
git
深海鱼在掘金11 天前
Git 完全指南 —— 第1章:Git 概览与版本控制演进
git
noravinsc12 天前
关于Git Flow
git
蜜獾云12 天前
在Git中配置用户名和密码
git