当前位置:   article > 正文

Git忽略规则及.gitignore规则不生效的解决办法_git exclude不生效

git exclude不生效

在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如无,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则例如:

*.a       # 忽略所有 .a 结尾的文件
!lib.a    # 但 lib.a 除外
/TODO     # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/    # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
  • 1
  • 2
  • 3
  • 4
  • 5

规则很简单,不做过多解释,但是有时候在项目开发过程中,突然心血来潮想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。我的问题就是出在了这儿, 导致浪费了很多时间. 首先, 我们来看该如何查看那些我们想要它被忽略的文件, 有没有被纳入了版本管理中呢? 方法如下:

  • 执行 git status 命令来查看
    这里写图片描述
    其中所列的”Untracked files”即为未被纳入版本管理中的文件

然后我们解决如何将已经被纳入版本管理中, 但却又是我们想要把它忽略的文件. 我们可以这么做: 先把本地缓存删除(改变成untracked状态),然后再提交:

  • git rm -r –cached .
  • git add -A
  • git commit -m “XXXXX”

还有一种方法, 全局范围内忽略文件:
在本地的根目录 “/.git/info/exclude” 文件中添加忽略规则, 忽略规则语法和上面的方法一样

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/小丑西瓜9/article/detail/618208
推荐阅读
相关标签
  

闽ICP备14008679号