git忽略已经提交的文件
2020-02-14 15:42:58 来源:admin 点击:1022
一、前言
我们以Android项目为例子,在新建项目的时候我们提交项目到仓库之前,会有一个.gitignore文件用于过滤文件或者文件夹,本人强烈建议在第一次新建的时候把该考虑到的都考虑进去,以免后期团队协作开发的时候引起不必要的麻烦,毕竟,时间就是金钱,哪怕是几分钟的事儿。
不过,很多朋友可能是中途接手项目,项目中的忽略文件不合理,此时此刻,我们第一会想到去修改.gitignore文件去忽略提交仓库的文件,但是发现修改完成后,目标文件还是能够提交的。
所以,我们应该怎样做呢?
二、解决办法
1.首先,我们要清楚,为什么我们在提交仓库之后修改了.gitignore去忽略目标文件不起作用?
原因:.gitignore只能忽略掉那些原来没有被追踪(track)的文件,所以如果有一些文件提交到了git仓库当中,接受了git追踪,那么直接修改.gitignore是无效的。所以建议在第一次提交项目时候,把该考虑到的考虑全。
2.忽略已提交的文件也有很多种不同情况,下面我说说常见的几种:
例如说,有些文件已经被提交,但是后期做项目的过程中,我们想要忽略这些文件的跟踪。这些文件在本地磁盘中还想保留着(简单说就是仓库上不会存在被忽略的文件,但是本地项目存在这些文件)
应用场景如下:
这里我们是在本地配置gradle的distributionUrl,由于每台电脑的gradle路径都不一样(如果电脑名不一样),所以
需要忽略掉此文件,并且本地是要保留的。这里 我直接把wrapper整个文件夹直接过滤掉。
操作如下:git rm --cached -r unpackage/*
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。