-->

架构资讯

您的当前位置:首页 > 资讯 > 版本控制工具

git忽略已经提交的文件

2020-02-14 15:42:58  来源:admin 点击:1083

一、前言

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

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

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

二、解决办法

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

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

2.忽略已提交的文件也有很多种不同情况,下面我说说常见的几种:

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

过滤gradle-wrapper.properties本地配置


这里我们是在本地配置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。


相关文章更多 >

© 2025版权所有 水水网

电话:171780793