所有分类
  • 所有分类
  • 未分类

glob匹配规则–使用

简介

说明

本文用示例介绍glob的匹配规则。

glob介绍

glob 是文件匹配模式(类似正则表达式),用来匹配文件路径(包括文件名),当然这里也可以直接指定某个具体的文件路径。当有多个匹配模式时,该参数可以为一个数组。

规则大全

匹配符含义
*匹配0个或多个字符。 不会匹配路径分隔符,除非路径分隔符出现在末尾
**匹配路径中的0个或多个目录及其子目录。 需要单独出现,即:左右必须是/,不能有其他字符。 如果出现在末尾,也能匹配文件。
?匹配文件路径中的一个字符(不会匹配路径分隔符)
[…]匹配方括号中出现的字符中的任意一个。 ^开头:表示不匹配方括号中其他字符中的任意一个。 -:表示范围。例如:[a-d],表示:a,b,c,d
{…}匹配多个属性。 例:src/{a,b}.js:匹配a.js和b.js文件);src/*.{jpg,png,gif}:匹配src下的所有jpg/png/gif文件;
!(pattern|pattern|pattern)匹配任何与括号中给定的任一模式都不匹配的
?(pattern|pattern|pattern)匹配括号中给定的任一模式0次或1次,类似于js正则中的(pattern|pattern|pattern)?
+(pattern|pattern|pattern)匹配括号中给定的任一模式至少1次,类似于js正则中的(pattern|pattern|pattern)+
*(pattern|pattern|pattern)匹配括号中给定的任一模式0次或多次,类似于js正则中的(pattern|pattern|pattern)*
@(pattern|pattern|pattern)匹配括号中给定的任一模式1次,类似于js正则中的(pattern|pattern|pattern)

示例

匹配符示例
*能匹配 a.js,x.y,abc,abc/,但不能匹配a/b.js
*.*能匹配 a.js,style.css,a.b,x.y
*/*/*.js能匹配 a/b/c.js,x/y/z.js,不能匹配a/b.js,a/b/c/d.js
**能匹配 abc,a/b.js,a/b/c.js,x/y/z,x/y/z/a.b,在未尾时能用来匹配所有的目录和文件
**/*.js能匹配 foo.js,a/foo.js,a/b/foo.js,a/b/c/foo.js
a/**/z能匹配 a/z,a/b/z,a/b/c/z,a/d/g/h/j/k/z
a/**b/z能匹配 a/b/z,a/sb/z,但不能匹配a/x/sb/z,因为只有单**单独出现才能匹配多级目录
?.js能匹配 a.js,b.js,c.js
a??能匹配 a.b,abc,但不能匹配ab/,因为它不会匹配路径分隔符
[xyz].js只能匹配 x.js,y.js,z.js,不会匹配xy.js,xyz.js等,整个中括号只代表一个字符

详解

*

说明

匹配文件中0个或者多个字符,但是不会匹配路径中的分隔符,除非路径分隔符出现在末尾。

示例

  • ./style/* :匹配./style目录下的 a.js,x.y,abc,abc/,不能匹配a/b.js
  • ./style/*.js :匹配./style目录下所有的js文件.
  • /style/*.* :匹配./style目录下所有的文件
  • ./style/*/*.js:只要层级相同,可以匹配任意目录下的任意js文件 比如./style/a/b.js,不能匹配a/b.js,a/b/c/d.js

**

说明

匹配路径中的0个或多个目录及其子目录,需要单独出现,即它左右不能有其他东西了。如果出现在末尾,也能匹配文件。

示例

./style/** :匹配style目录所有的目录和文件。能匹配:

  1. ./style/lib    
  2. ./style/mudules/b
  3. ./style/a.js
  4. ./style/lib/res.js
  5. ./style/mudules/b/a.js

例2:./style/**/*.js :匹配style目录及其所有子目录下的所有js文件。能匹配:

  1.  ./style/a.js
  2.  ./style/lib/res.js
  3.  ./style/mudules/b/a.js

例3:./style/**/* :匹配style目录下的所有目录和文件。能匹配

  1.  ./style/a.js
  2.  ./style/bb
  3. ./style/images/c.png

例4:a/**b/z :

  1. 能匹配 a/b/z,a/sb/z
  2. 不能匹配a/x/sb/z,因为只有单**单独出现才能匹配多级目录

?

说明

匹配一个字符,不会匹配路径分隔符

示例

  1. ?.js:
    1. 能匹配文件名只有一个字符的js文件,如a.js, b.js
    2. 不能匹配文件名为2个字符及其以上的js的文件

[…]

说明

由多个规则组成的数组,可以匹配数组中符合任意一个子项的文件。

  • ^开头:表示不匹配方括号中其他字符中的任意一个。
  • -开头:表示范围。例如:[a-d],表示:a,b,c,d

示例

  • ./style/a[0-3].js : 匹配style目录下的a0.js, a1.js, a2.js, a3.js
  • [xyz].js :只能匹配 x.js, y.js, z.js,不会匹配xy.js, xyz.js等。整个中括号只代表一个字符
  • [^xyz].js :能匹配 a.js,b.js,c.js等,不能匹配x.js, y.js, z.js

排除模式

使用数组的方式还有一个好处就是可以很方便的使用排除模式,在数组中的单个匹配模式前加上!即是排除模式,它会在匹配的结果中排除这个匹配。

不能在数组中的第一个元素中使用排除模式

示例

  • [*.js,’!b*.js’]:匹配所有js文件,但排除掉以b开头的js文件
  • [‘!b*.js’,*.js]:不会排除任何文件,因为排除模式不能出现在数组的第一个元素中

{…}

说明

展开模式,根据里面的内容展开为多个规则,能匹配所有展开之后的规则将上面的例子扩展一下。

示例

  • a{b,c}d 会展开为 abd, acd
  • a{b,}c 会展开为 abc, ac
  • a{0..3}d 会展开为 a0d, a1d, a2d, a3d
  • a{b,c{d,e}f}g 会展开为 abg, acdfg, acefg
  • a{b,c}d{e,f}g 会展开为 abdeg, acdeg, abdeg, abdfg
  • [‘./**/*.{html, php}’, ‘!{build, simple, images, node_modules}/**’] :除去build,simple,images,node_modules目录,匹配根目录下所有的html与php文件

!(pattern|pattern|pattern)

说明

排除符合这几个模式的所有文件。

示例

  1. ./style/!(?|jquery).js
    1. 匹配排除文件名为一个字符的js文件,以及排除jquery.js之后的所有js文件
  2. [‘./**/!(_)*.{html, php}’, ‘!{build, node_modules}/**’]
    1. 排除build与node_modules目录,并排除其他目录下以下划线_开头的html与php文件,匹配其余的html与php文件

?(pattern|pattern|pattern)

说明

匹配括号中给定的任一模式0次或者1次,类似于js正则中的(pattern|pattern|pattern)?

示例

  1. ‘./style/?(a|a2|b).js’
    1. 匹配style目录下的a.js, a2.js, b.js,不能组合,匹配0次或者1次

@(pattern|pattern|pattern)

说明

匹配多个模式中的任一个,类似于js正则中的(pattern|pattern|pattern)

示例

  1. ./style/@(a|b|c).js
    1. 匹配style目录下的a.js, b.js, c.js,不能组合,匹配一次,不能为空。注意与?的区别

+(pattern|pattern|pattern)

说明

匹配括号中给定任一模式1次或者多次,这几个模式可以组合在一起匹配,类似于js正则中的(pattern|pattern|pattern)+

示例

  1. ./style/+(a|a2|b).js
    1. 匹配style目录下的a.js, a2.js, b.js,也可以匹配他们的组合 ab.js, aa2.js, a2b.js等,至少匹配一次,为空不匹配。

*(pattern|pattern|pattern) 

说明

匹配括号中给定任一模式0次或者多次,这几个模式可以组合在一起匹配,类似于js正则中的(pattern|pattern|pattern)*

示例

  1. ./style/*(a|b|c).js
    1. 可以匹配style目录下的a.js, b.js, c.js,也可以匹配他们的组合 ab.js, bc.js, ac.js,匹配0次或者多次。

0

评论0

请先

显示验证码
没有账号?注册  忘记密码?

社交账号快速登录