忽略文件或文件夹加入版本控制

过滤规则

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

语法配置

  • ?:代表任意的一个字符
  • *:代表任意数目的字符
  • {!ab}:必须不是此类型
  • {ab,bb,cx}:代表ab,bb,cx中任一类型即可
  • [abc]:代表a,b,c中任一字符即可
  • [ ^abc]:代表必须不是a,b,c中任一字符

在gitigonre中配置

在gitigonre中配置

特殊情况

第一种情况

就是已经commit了,再加入gitignore是无效的,所以需要删除下缓存

git rm -r --cached ignore_file

注意: .gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。
正确的做法是在每个clone下来的仓库中手动设置不要检查特定文件的更改情况。
git update-index --assume-unchanged PATH 在PATH处输入要忽略的文件。

第二种情况

另外 git 还提供了另一种 exclude 的方式来做同样的事情,不同的是 .gitignore 这个文件本身会提交到版本库中去。用来保存的是公共的需要排除的文件。而 .git/info/exclude 这里设置的则是你自己本地需要排除的文件。 他不会影响到其他人。也不会提交到版本库中去。

pull过滤

git update-index --assume-unchanged PATH 在PATH处输入要忽略的文件。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容