git checkout仓库项目某个文件夹

    最近新公司学习相应的代码逻辑,使用SVN作为项目的托管工具,实属不大习惯,尤其对于用惯了git的人来说。一度想尝试使用git-svn的组合拳的方式,间接通过git来实现git才有的本地仓库。反正最终没落实,也就这样,去熟悉SVN的那一套逻辑,其实也还OK,接受范围之内。

    不过,今天有个同事来问我git是否可以像SVN那样单独拉下仓库里的某个文件夹或者某些文件呢,毕竟整个项目结构这么庞大,不一定每个项目文件都是需要的,只需要拉下开发需求的文件就行。自认为git知识还是相当熟透的我,觉得问题应该不大,但是实操却发现,这有点难受,好像git并没有留下对应的命令操作方式。如果使用SVN还比较简单点,大体实现如下:

# 先checkout空目录

svn co--depthempty svnLocation localDir

# 对需要的子目录递归checkout

svn update--set-depthinfinity localDir/data

svn update--set-depthinfinity localDir/block


  后来谷歌研究了下实现方法,原来还是有方式可以去实现的,我就觉得嘛,万能的git哪有实现不了的东西。于是我尝试进行了这么些操作,只能说感谢先人。

  因为SVN是基于文件方式存储的,而git是基于元数据方式分别式存储文件信息的,注定每次clone的时候都会将所有信息都取回至本地,并在本地生成一个克隆版的版本库。但是发现在Git 1.7.0之后,新加入了Sparse checkout模式,可以实现指定checkout指定文件或者文件夹到本地。具体实现我们可以尝试下:

  1. 创建一个文件夹checkout_part_from_git

  2. 打开git bash,进入文件夹对应路径,执行git init初始化仓库

  3. git remote add -f origin <url> 将远程URL加入到git config中

 4. git config core.sparsecheckout true 允许config中使用Sparse checkout模式

5. 需要指定checkout哪个文件夹或者哪个文件

    echo "game/region" >> .git/info/sparse-checkout

6. 最后将远程分支上的项目拉下来: git pull origin master

大功告成!

过程展示如下:


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 本片内容转自CSDN http://blog.csdn.net/ithomer/article/details/7...
    五娃儿阅读 4,958评论 2 88
  • git常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,660评论 1 26
  • 系统默认的通知风格 可以看到,Android通知栏默认是标题显示一行,内容显示一行,对于一行显示不完的,用省略号代...
    骑着海去看蜗牛阅读 20,360评论 8 44
  • 语录 l人的心是很大的,放得下我们喜欢的每一样东西。 l当你停止喜欢一个人,他就会在你心里慢慢死去。 l我从来不期...
    呼噜毛阅读 1,582评论 0 0