在编写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 })?
|
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
原文链接:http://www.minunix.com/2014/12/ruby_regexp/