Git本地忽略文件夹,只拉取目标文件夹

前情:我的路径为F:\UnityProject\TGILab\pico\UnityProject\Assets\EaseVSim,其中EaseVSim是一个独立的子模块文件夹,如果没有子模块只执行步骤3之后的内容即可。

  1. 关闭unity程序

  2. 因子模块已经在本地存在,执行稀疏检出可能无效,建议先把EaseVSim子模块下的内容暂存/复制/提交,确保子模块下无重要内容之后执行以下命令,删除重新加载EaseVSim子模块

    以下命令行按顺序执行

    2.1 进入项目目录
    cd /f/UnityProject/TGILab/pico(换成自己的路径)

    2.2 停用子模块
    git submodule deinit -f -- UnityProject/Assets/EaseVSim

    2.3 删除子模块的本地仓库缓存
    rm -rf .git/modules/Assets/EaseVSim

    2.4 删除子模块的工作目录
    rm -rf UnityProject/Assets/EaseVSim

    2.5 重新初始化并克隆子模块
    git submodule update --init --recursive --UnityProject/ Assets/EaseVSim

    之后子模块切换到main分支

  3. 命令行进入子模块目录
    cd /f/UnityProject/TGILab/UnityProject/Assets/EaseVSim

  4. 打开稀疏检出开关
    git config core.sparseCheckout true

  5. 打开子模块的目录(如果没有子模块直接打开.git/info)
    F:\UnityProject\TGILab\pico\.git\modules\UnityProject\Assets\EaseVSim\info

    换成自己的本地目录,找到info下面 sparse-checkout 文件

    (如果没有的话新建一个sparse-checkout.txt文件,删除后缀),右键记事本打开

    全选删除,根据自己项目情况,增删下面的记录,注意之前不要有空格

/*

!AAAExpms/DengGaoZY/

!AAAExpms/DengGaoZY.meta

第一行的/*代表全部文件,后面的 开头代表忽略这个文件夹,取消忽略就删除上面文件内容

  1. 保存文件,还是打开之前的命令行,执行
    git reset --hard HEAD

强制刷新一下就可以了,其他同事如果在本地已忽略的文件夹提交文件不会更新,更新子模块也不会失效

相关推荐
MY_TEUCK6 小时前
【git工具篇】Git 常用实战手册:从基础命令到分支冲突解决(开发实战版)
大数据·git
幸运的大号暖贴7 小时前
解决Vibe Coding时Idea经常不自动git add问题
java·人工智能·git·intellij-idea·claudecode·opencode
摇滚侠8 小时前
如何打开 GitHub,GitHub 是基于 Git 版本控制系统的在线代码托管平台
git·github
MY_TEUCK9 小时前
【Git 实习生小白专用】:最安全、永不翻车、公司最爱 的标准版本控制工作流程
git·安全·github
donecoding10 小时前
第一次用 git worktree,连踩了三个坑(附无痛清理姿势)
git
spmcor10 小时前
解决 Git 中已跟踪目录无法被 .gitignore 忽略的问题
git
qcx2312 小时前
【AI Engineering · Harness 系列】02 确定性外壳 × 非确定性内核——git push 红线的故事
人工智能·git·prompt·agent·engineering·harness
水云桐程序员12 小时前
10 分钟 Git 上手教程
git
Dontla12 小时前
Git三个主要区域介绍(工作区Working Directory、暂存区Index/Staging Area、仓库区Repository)
git