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

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

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