Loading... > 转载文章,排版可能出现错误,建议到原文阅读:https://blog.csdn.net/shelutai/article/details/123116973 Git [Sparse](https://so.csdn.net/so/search?q=Sparse&spm=1001.2101.3001.7020) Checkout使用指南 Git的clone,默认是直接拉取整个远程仓库,如果项目比较大,在进行clone时,会导致拉取到大量和自己无关的内容到本地,占用很多硬盘空间。 Git在1.7版本后,已经支持只Checkout部分内容,这个功能叫做 Sparse Checkout(稀疏检出),使用该功能可以节省本地硬盘空间。 使用步骤 准备工作:如果本地还没有版本库,则先执行下述命令 ```bash git init <project> cd <project> git remote add origin ssh://<user>@<repository's url> ``` 1.开启sparse checkout功能 开启: ```bash git config core.sparsecheckout true ``` 或者 git sparse-checkout init 2.写入要获取的文件 1)写入文件: echo “x x x” >> .git/info/sparse-checkout 例如: ```bash echo "Test" >> .git/info/sparse-checkout ``` 表示只拉取Test文件夹, 或者使用命令 git sparse-checkout set Test 附:sparse checkout文件设置 ``` 子目录的匹配 ``` 在 sparse-checkout 文件中,如果目录名称前带斜杠,如/docs/,将只匹配项目根目录下的docs目录,如果目录名称前不带斜杠,如docs/,其他目录下如果也有这个名称的目录,如test/docs/也能被匹配。 而如果写了多级目录,如docs/01/,则不管前面是否带有斜杠,都只匹配项目根目录下的目录,如test/docs/01/不能被匹配。 ``` 通配符 “*“ (星号) ``` 在 sparse-checkout 文件中,支持通配符 “\*“,如可以写成以下格式: _docs/ index._ \*.gif ``` 排除项 “!” (感叹号) ``` 在 sparse-checkout 文件中,也支持排除项 “\!”,如只想排除排除项目下的 “docs” 目录,可以按如下格式写: /\* \!/docs/ 注意:如果要关闭sparsecheckout功能,全取整个项目库,可以写一个”\*“号,但如果有排除项,必须写成”/星号“,同时排除项要写在通配符后面。 2)执行git pull/fetch命令 (每次更改sparse-checkout增加或删除目录时,都需要执行一次该命令)。 3.关闭sparse checkout功能 使用命令: git sparse-checkout disable 最后修改:2024 年 06 月 04 日 10 : 22 AM © 来自互联网 赞赏 要多恰饭才能长胖 赞赏作者 支付宝微信