.gitignore语法

一、为什么使用 .gitignore ?


在一些项目中,我们不想让本地仓库的所有文件都上传到远程仓库中,而是有选择的上传,比如:一些依赖文件(node_modules下的依赖)、bin 目录下的文件、测试文件等。一方面将一些依赖、测试文件都上传到远程传输量很大,另一方面,一些文件对于你这边是可用的,在另一个人那可能就不可用了,比如:本地配置文件。

为了解决上述问题,git 引入了 .gitignore 文件,使用该文件来选择性的上传文件。

二、使用规则

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

以上规则意思是:被过滤掉的文件就不会出现在你的GitHub库中了,当然本地库中还有,只是push的时候不会上传。

除了以上规则,它还可以指定要将哪些文件添加到版本管理中。

!src/   不过滤该文件夹
!*.zip   不过滤所有.zip文件
!/mtk/do.c 不过滤该文件

1、配置语法:

  • 斜杠/开头表示目录;
  • 星号*通配多个字符;
  • 问号?通配单个字符
  • 方括号[]包含单个字符的匹配列表;
  • 叹号!表示不忽略(跟踪)匹配到的文件或目录;

此外,git 对于 .ignore 配置文件是按行从上到下进行规则匹配的,意味着如果前面的规则匹配的范围更大,则后面的规则将不会生效;

2、示例说明

a、规则:fd1/*
说明:忽略目录 fd1 下的全部内容;注意,不管是根目录下的 /fd1/ 目录,还是某个子目录 /child/fd1/ 目录,都会被忽略;
b、规则:/fd1/*
说明:忽略根目录下的 /fd1/ 目录的全部内容;
c、规则:
/*
!.gitignore
!/fw/bin/
!/fw/sf/
说明:忽略全部内容,但是不忽略 .gitignore 文件、根目录下的 /fw/bin/ 和 /fw/sf/ 目录;

3、注意

  • “#” 表示注释
  • “!”  表示取消忽略
  • 空行不作匹配
  • 若匹配语句中无“/ ” ,便将其视为一个 glob匹配,如'abc'可以匹配 ' abc' , 'cd/abc' , 'ef/abcde.txt'
  • 若匹配语句中有'/ ' ,便视为一个路径匹配,如'abc/'可以匹配 ' abc' , 'cd/abc' ,但是无法匹配 'ef/abcde.txt'
  • 若匹配语句以'/ ' 开始,便视为匹配当前目录,如'/abc'可以匹配 ' abc' 但无法匹配 'cd/abc' 
  • ** 表示匹配零到多级目录

4、示例

# dependencies  npm包文件
/node_modules

# production  打包文件
/build

# misc 
.DS_Store

npm-debug.log*

.DS_Store:这个文件是Mac OS X用来存储文件夹的一些诸如自定义图标,ICON位置尺寸,窗口位置,显示列表种类以及一些像窗体自定义背景样式,颜色这样的元信息。默认情况下,Mac OS X下的每个文件夹下应该都会生成一个,包括网络介质存储盘和U盘这样的外部设备。

npm-debug.log:项目主目录下总是会出现这个文件,而且不止一个,原因是npm i 的时候,如果报错,就会增加一个此文件来显示报错信息,npm install的时候则不会出现。

最后需要强调的一点是,如果你不慎在创建.gitignore文件之前就push了项目,那么即使你在.gitignore文件中写入新的过滤规则,这些规则也不会起作用,Git仍然会对所有文件进行版本管理。
简单来说,出现这种问题的原因就是Git已经开始管理这些文件了,所以你无法再通过过滤规则过滤它们。因此一定要养成在项目开始就创建.gitignore文件的习惯,否则一旦push,处理起来会非常麻烦。

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
.gitignore 语法可以通过以下几种规则来过滤文件和文件夹: 1. 使用斜杠(/)表示匹配到一个目录或文件,斜杠可以用于规则的起始、中间和尾部。例如,规则 "App.vue" 可以匹配到任意位置的 App.vue 文件。 2. 使用感叹号(!)表示取反操作,即让 Git 再次跟踪被忽略的文件或目录。但需要注意的是,指定忽略的文件或目录的父目录不能被整体忽略。例如,如果先包含 "src" 目录,然后忽略 "!src/App.vue" 是无效的,应该写成 "src/*",然后再忽略 "!src/App.vue"。 3. 使用星号(*)表示匹配任意字符,包括目录分隔符(斜杠)。例如,规则 "abc/**" 表示匹配 "abc" 之后任意目录下的文件。 4. 使用双星号(**)有三种语义:**/foo 表示匹配任意目录下的 "foo" 文件;"abc/**" 表示匹配 "abc" 之后任意目录下的文件;"a/**/b" 表示匹配 "a" 目录下任意级别的子目录 "b"。 5. 使用井号(#)表示注释,在注释后的内容会被忽略。 6. 空白符,如空格和回车,会被 Git 忽略,可以使用空格和回车来使得文件更易读。 除了 .gitignore 文件,还有其他工具也会使用 ignore 文件,如 .eslintignore, .prettierignore 等,它们的语法与 .gitignore 一样。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [.gitignore语法](https://blog.csdn.net/yuan_jlj/article/details/125148321)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [.gitignore 语法](https://blog.csdn.net/huangpb123/article/details/125175028)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值