git_旧瓶新酒?谈.gitignore文件不起作用的解决方案

版权声明:本文为博主原创文章,未经博主允许不得转载。(Copyright © https://blog.csdn.net/s_gy_zetrov. All Rights Reserved) https://blog.csdn.net/S_gy_Zetrov/article/details/84553276

git中.gitignore文件不起作用的解决

本篇内容实际上很多博客已经提到了,但是我想说的,是经过实际测试有效的解决方法。

什么情况下.gitignore文件会失效

当你已经使用git来track了一些不想要的文件时,这些文件是无法被.gitignore文件忽略的。

比如:你的git仓库中有3个文件,A.tex, B.log, C.aux。如果你在建立仓库时没有添加.gitignore文件,而是选择了直接commit -am,则后续再添加.gitignore文件如

############################################
## LATEX TEMPORARY FILES
############################################

*.log
*.aux

时,git是不会去忽略*.log*.aux文件的。原因就是这些文件已经被git给cache了,也就是被缓存了。所以解决方案就是让git重新去缓存整个仓库,把不想要的文件统统通过重新缓存这个操作来“丢”掉。

网上普遍的解决办法(测试通过,有效)

注意命令最后的英文句号是要带上的!

git rm -r --cached .
git add .
git commit -m 'updated .gitignore file'

这样3条命令结束后,git就会将你不想要的文件,从缓存中丢掉,也就是终于使.gitignore文件生效。

猜你喜欢

转载自blog.csdn.net/S_gy_Zetrov/article/details/84553276