perl常用正则匹配

匹配次数的控制

x? 匹配 0 次或一次 x 字符串(?:表示0次或一次)

x* 匹配 0 次或多次 x 字符串,但匹配可能的最少次数

x+ 匹配 1 次或多次 x 字符串,但匹配可能的最少次数

.* 匹配 0 次或多次的任何字符

.+ 匹配 1 次或多次的任何字符

{m} 匹配刚好是 m 次的指定字符串

{m,n} 匹配在 m次以上n次以下 的指定字符串

{m,} 匹配 m次以上的指定字符串

匹配内容的控制

匹配除换行符以外的所有字符

[] 匹配符合[] 内的字符

[^] 匹配不符合[] 内的字符

[0-9] 或者为\d匹配所有数字字符

[a-z] 匹配所有小写字母字符

[^0-9] 匹配所有非数字字符

[^a-z] 匹配所有非小写字母字符

匹配字符开头的字符

匹配字符结尾的字符

\d 匹配所有的数字字符同[0-9]

\D 非数字,其他同 \d

\w 英文字母或数字的字符串,和 [a-zA-Z0-9] 语法一样

\W 非英文字母或数字的字符串,和 [^a-zA-Z0-9] 语法一样

\s 空格,和 [\n\t\r\f] 语法一样

\S 非空格,和 [^\n\t\r\f] 语法一样

\b 匹配以英文字母,数字为边界的字符串

\B 匹配不以英文字母,数值为边界的字符串

a|b|c 匹配符合a字符或是b字符或是c字符的字符串

匹配内容的控制

(pattern) :() 这个符号会记住所找寻到的字符串,是一个很实用的语法。第一个 () 内所找到的字符串变成 $1 这个变量,第二个 () 内所找到的字符串变成 $2 这个变量,以此类推。

/pattern/i: i 这个参数表示忽略英文大小写,也就是在匹配字符串的时候,不考虑英文的大小写问题。同样的用法有g(全局),i(忽略大小写),m(多行),o(只一次),s(单行),x(多余空格)等。

/\*/:\这个用于表示转义字符。例如要在 pattern 模式中找寻 "*",则要在这个字符前加上 \ 符号。

下面给出一些例子:

/perl/ 找到含有 perl 的字符串

/^perl/ 找到开头是 perl 的字符串

/perl$/ 找到结尾是 perl 的字符串

/c|g|i/ 找到含有 c  g  i 的字符串

/cg{2,4}i/ 找到 c 后面跟着 2个到 4 g ,再跟着 i 的字符串

/cg{2,}i/ 找到 c 后面跟着 2个以上 g ,再跟着 i 的字符串

/cg{2}i/ 找到 c 后面跟着 2 g,再跟着 i 的字符串

/cg*i/ 找到 c 后面跟着 0个或多个 g ,再跟着 i 的字符串,如同/cg{0,}i/

/cg+i/ 找到 c 后面跟着一个以上 g,再跟着 i 的字符串,如同/cg{1,}i/

/cg?i/ 找到 c 后面跟着 0个或是 1 g ,再跟着 i 的字符串,如同/cg{0,1}i/

/c.i/ 找到 c 后面跟着一个任意字符,再跟着 i 的字符串

/c..i/ 找到 c 后面跟着二个任意字符,再跟着 i 的字符串

/[cgi]/ 找到符合有这三个字符任意一个的字符串

/[^cgi]/ 找到没有这三个字符中任意一个的字符串

/\d/ 找寻符合数字的字符,可以使用/\d+/来表示一个或是多个数字组成的字符串

/\D/ 找寻符合不是数字的字符,可以使用/\D+/来表示一个或是更多个非数字组成的字符串

/\*/ 找寻符合 * 这个字符,因为 * 在常规表达式中有它的特殊意思,所以要在这个特殊符号前加上 \ 符号,这样才会让这个特殊字符失效

/abc/i 找寻符合 abc 的字符串而且不考虑这些字符串的大小写

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值