在编写puppet的pp文件中,会用到很多ruby的正则表达式,常用的正则如下:
正则表达式:
[codesyntax lang="ruby"]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
{}: 重复次数(如 { 4 }表示前面的会重复出现恰好 4 次) {m,n}: 前面元素最少出现m次,最多出现n次 []: 范围描述符(如 [a-z]表示在a-z范围内的一个字母) \w: 字符或数字,相当于[ 0 - 9A -Za-z] \ W : 非字母或数字 \s: [\t\n\r\f]空字符,相当于[\t\n\r\f] \ S : 非空字符 \d: [ 0 - 9 ]数字,相当于[ 0 - 9 ] \ D : 非数字字符 *: 前面元素出现 0 次或多次 +: 前面元素出现 1 次或多次 ?: 前面元素最多出现 1 次 |:与前面或后面的表达式匹配 \b: 退格符(0x08)(仅在范围描述符内部时) \b: 字边界(word boundary)(在范围描述符外部时) \ B : 非字边界 |
实例:[codesyntax lang="ruby"]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
= begin 非负整数(正整数+ 0 ): ^\d+$ 正整数: ^[ 0 - 9 ]*[ 1 - 9 ][ 0 - 9 ]*$ 非正整数(负整数+ 0 ): ^((-\d+)|( 0 +))$ 由 26 个英文字母组成的字符串: ^[ A -Za-z]+$ 由数字和 26 个英文字母组成的字符串: ^[ A -Za-z0- 9 ]+$ E -mail地址: ^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$ 年-月-日: 中文字符: [\u4e00-\u9fa5] 双字节字符(包括汉字在内): [^\x00-\xff] HTML 标记: /<.*>.*<\/\ 1 >|<.*>\/>/ 账号是否合法(字母开头,允许 5 - 16 个字节,允许字母数字下划线): ^[ A -Za-z][a-zA- Z0 - 9_ ]{ 4 , 15 }$ 电话号码: (\d{ 3 }-|\d{ 4 }-)?(\d{ 8 }|\d{ 7 })? 腾讯 QQ 号: ^[ 1 - 9 ]*[ 1 - 9 ][ 0 - 9 ]*$ |
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://www.minunix.com/2014/12/ruby_regexp/