当前位置:   article > 正文

用git按需下载github仓库部分/单个文件夹的方法_git下载 仓库单个目录

git下载 仓库单个目录

用git按需下载github仓库部分/单个文件夹的方法

Git 的 sparse checkout 跟 shallow clone/pull

想下载个大仓库到本地,但是zip文件老是出错而且下载时间长,遂使用此方法完成独立的文件夹下载。
步骤

(2~4顺序可换):

  1. 建立一个空的git 本地仓库:
    $ git init new.project && cd new.project
    
    • 1
  2. 在本地仓库里面启用sparse-checkout:
    $ git config core.sparseCheckout true
    
    • 1
  3. 设定你要checkout 哪些文件夹(如/xxx/*表示xxx文件夹下所有文件)(也可以用vim直接打开 .git/info/sparse-checkout写入)
    $ echo '/xxx/*' >> .git/info/sparse-checkout
    
    • 1
  4. 设定remote (要从哪里clone/pull?):
    $ git remote add origin git://github.com/xxx/xxx.git
    
    • 1
  5. 然后就可以开始pull 了(这边可以加上后面说的shallow pull,加上–depth=n
    $ git pull origin master
    
    • 1

之后

  1. 如果只拉取最近一次的变更,忽略以前的变更记录,在拉取时可以加参数depth,如git pull --depth=1 origin master (浅克隆)

  2. 如果以后修改了 .git/info/sparse-checkout,增加或删除部分目录,可以执行如下命令重新Checkout

    $ git checkout master
    
    • 1

    或执行以下命令:

    $ git read-tree -mu HEAD
    
    • 1

    如果本地已经建了版本库,要使用这个功能,可以进入版本库的目录,执行以下命令

    $ git config core.sparsecheckout true
    $ echo "/xxx/*" >> .git/info/sparse-checkout
    $ echo "/xxx" >> .git/info/sparse-checkout
    $ git checkout master
    
    • 1
    • 2
    • 3
    • 4
  3. 要关闭 sparse checkout功 能,仅仅修改设置,将core.sparsecheckout设为false是不生效的,需要修改 .git/info/sparse-checkout 文件,用一个”*“号替代其中的内容,然后执行 checkout 或 read-tree 命令。

转载于博客园impwa

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号