简介
说明
本文用示例介绍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目录所有的目录和文件。能匹配:
- ./style/lib
- ./style/mudules/b
- ./style/a.js
- ./style/lib/res.js
- ./style/mudules/b/a.js
例2:./style/**/*.js :匹配style目录及其所有子目录下的所有js文件。能匹配:
- ./style/a.js
- ./style/lib/res.js
- ./style/mudules/b/a.js
例3:./style/**/* :匹配style目录下的所有目录和文件。能匹配
- ./style/a.js
- ./style/bb
- ./style/images/c.png
例4:a/**b/z :
- 能匹配 a/b/z,a/sb/z
- 不能匹配a/x/sb/z,因为只有单**单独出现才能匹配多级目录
?
说明
匹配一个字符,不会匹配路径分隔符
示例
- ?.js:
- 能匹配文件名只有一个字符的js文件,如a.js, b.js
- 不能匹配文件名为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)
说明
排除符合这几个模式的所有文件。
示例
- ./style/!(?|jquery).js
- 匹配排除文件名为一个字符的js文件,以及排除jquery.js之后的所有js文件
- [‘./**/!(_)*.{html, php}’, ‘!{build, node_modules}/**’]
- 排除build与node_modules目录,并排除其他目录下以下划线_开头的html与php文件,匹配其余的html与php文件
?(pattern|pattern|pattern)
说明
匹配括号中给定的任一模式0次或者1次,类似于js正则中的(pattern|pattern|pattern)?
示例
- ‘./style/?(a|a2|b).js’
- 匹配style目录下的a.js, a2.js, b.js,不能组合,匹配0次或者1次
@(pattern|pattern|pattern)
说明
匹配多个模式中的任一个,类似于js正则中的(pattern|pattern|pattern)
示例
- ./style/@(a|b|c).js
- 匹配style目录下的a.js, b.js, c.js,不能组合,匹配一次,不能为空。注意与?的区别
+(pattern|pattern|pattern)
说明
匹配括号中给定任一模式1次或者多次,这几个模式可以组合在一起匹配,类似于js正则中的(pattern|pattern|pattern)+
示例
- ./style/+(a|a2|b).js
- 匹配style目录下的a.js, a2.js, b.js,也可以匹配他们的组合 ab.js, aa2.js, a2b.js等,至少匹配一次,为空不匹配。
*(pattern|pattern|pattern)
说明
匹配括号中给定任一模式0次或者多次,这几个模式可以组合在一起匹配,类似于js正则中的(pattern|pattern|pattern)*
示例
- ./style/*(a|b|c).js
- 可以匹配style目录下的a.js, b.js, c.js,也可以匹配他们的组合 ab.js, bc.js, ac.js,匹配0次或者多次。
请先
!