前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >.gitignore文件作用

.gitignore文件作用

原创
作者头像
陈不成i
修改2021-05-28 14:29:38
8370
修改2021-05-28 14:29:38
举报
文章被收录于专栏:ops技术分享

一.简介

一般来说每个Git项目中都需要一个.gitignore文件,这个文件的作用就是告诉Git哪些文件不需要添加到版本管理中。

意思就是本地修改完项目后,上传到github等版本管理服务中,本地哪些文件不上传过去。

实际项目中,很多文件都是不需要版本管理的,比如Python的.pyc文件和一些包含密码的配置文件等等。

这个文件的内容是一些规则,Git会根据这些规则来判断是否将文件添加到版本控制中。

二.常用规则

vim .gitignore

  1. /mtk/ #过滤整个文件夹
  2. *.zip #过滤所有.zip文件
  3. /mtk/do.c #过滤某个具体文件

很简单吧,被过滤掉的文件就不会出现在你的GitHub库中了,当然本地库中还有,只是push的时候不会上传。

三.详细

需要注意的是,gitignore还可以指定要将哪些文件添加到版本管理中:

  1. !*.zip
  2. !/mtk/one.txt

唯一的区别就是规则开头多了一个感叹号,Git会将满足这类规则的文件添加到版本管理中。

为什么要有两种规则呢?想象一个场景:我们只需要管理/mtk/目录中的one.txt文件,这个目录中的其他文件都不需要管理。那么我们就需要使用:

  1. /mtk/
  2. !/mtk/one.txt

假设我们只有过滤规则没有添加规则,那么我们就需要把/mtk/目录下除了one.txt以外的所有文件都写出来!

最后需要强调的一点是,如果你不慎在创建.gitignore文件之前就push了项目,那么即使你在.gitignore文件中写入新的过滤规则,这些规则也不会起作用,Git仍然会对所有文件进行版本管理。

简单来说,出现这种问题的原因就是Git已经开始管理这些文件了,所以你无法再通过过滤规则过滤它们。

所以大家一定要养成在项目开始就创建.gitignore文件的习惯,否则一旦push,处理起来会非常麻烦。

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一.简介
  • 二.常用规则
  • 三.详细
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档