git使用随笔:如何忽略已提交到仓库的文件或者文件夹

一、前言

我们以Android项目为例子,在新建项目的时候我们提交项目到仓库之前,会有一个.gitignore文件用于过滤文件或者文件夹,本人强烈建议在第一次新建的时候把该考虑到的都考虑进去,以免后期团队协作开发的时候引起不必要的麻烦,毕竟,时间就是金钱,哪怕是几分钟的事儿。

不过,很多朋友可能是中途接手项目,项目中的忽略文件不合理,此时此刻,我们第一会想到去修改.gitignore文件去忽略提交仓库的文件,但是发现修改完成后,目标文件还是能够提交的。

所以,我们应该怎样做呢?

二、解决办法

1.首先,我们要清楚,为什么我们在提交仓库之后修改了.gitignore去忽略目标文件不起作用?

原因:.gitignore只能忽略掉那些原来没有被追踪(track)的文件,所以如果有一些文件提交到了git仓库当中,接受了git追踪,那么直接修改.gitignore是无效的。所以建议在第一次提交项目时候,把该考虑到的考虑全。

2.忽略已提交的文件也有很多种不同情况,下面我说说常见的几种:
  • 例如说,有些文件已经被提交,但是后期做项目的过程中,我们想要忽略这些文件的跟踪。这些文件在本地磁盘中还想保留着(简单说就是仓库上不会存在被忽略的文件,但是本地项目存在这些文件)
    应用场景如下:

    过滤gradle-wrapper.properties本地配置

    这里我们是在本地配置gradle的distributionUrl,由于每台电脑的gradle路径都不一样(如果电脑名不一样),所以需要忽略掉此文件,并且本地是要保留的。这里 我直接把wrapper整个文件夹直接过滤掉。
    操作如下:
    git rm --cached -r gradle/wrapper
    然后修改项目.gitignore文件添加过滤规则:gradle/wrapper
    然后commit
    最后push

  • 还有种情况,在我们已经提交过的一些文件中,在后期由于种种原因发现不需要某个文件,我们想这些文件被彻底删除时候。
    操作如下:
    git rm somefiles 从本地移除这个文件,并且删除本地缓存
    更新gitignore文件,忽略目标文件(somefiles)
    然后commit
    最后push

三、总结

1.下面我说说rm命令系列的作用和用法与区别:
  • rm
    单纯的删除本地文件,与git没有任何关系,所以git上是不会有该删除记录的
  • git rm
    删除git追踪文件,并删除本地文件,git上会保存此次删除记录
  • git rm --cached -r
    单单删除git追踪文件,不删除本地文件
2.为什么增加了.gitignore里的规则却没有效果?
  • 我在文章开始也简单提到了,那是因为.gitignore文件只能作用于未跟踪的文件(Untracked Files),也就是从来没有被Git记录过的文件。所以要先从Git索引中删除对改文件的追踪,才能使.gitignore文件生效。而删除文件的追踪是git rm,这种做法会将本地的物理文件一并删除。如果想要删除追踪状态而非物理文件,可以使用git rm --cached。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文为 Git教程的学习笔记,教程源自廖雪峰的博客。这是一个由浅入深,学完后能立刻上手的Git教程。另,附上另一本...
    七弦桐语阅读 11,387评论 5 47
  • 关于我想要做兼职挣钱的起源,大概就是问家里要钱搞毕业旅行被拒。傲气的我,发誓不再问家里要钱,身上仅剩400块...
    打油诗人张正义阅读 9,469评论 3 5
  • 需要导入的头文件: #define IOS_CELLULAR @"pdp_ip0" #define IOS_WI...
    没技术的BUG开发攻城狮阅读 6,471评论 0 1
  • 初到深圳,是在五月之初,此时的深圳的早已被染绿,葱葱蓉蓉,却不是我喜欢的颜色,作为男人,我不喜欢绿色。 来...
    你家凯爷阅读 2,615评论 1 1