1. 反向引用:
表达式:
(.)(..)\1\2\1
-->(.):任意一个字符
-->(..)任意两个字符
-->\1:表示第一个任意字符,即和(.)相同
-->\2:表示第二个任意字符,即和(..)相同
-->\1:表示第一个任意字符,即和(.)相同
备注:如何区分每个括号对应的第几组,按照左括号依次计数
- 举例
$_="yabba dabba doo";
if (/y(.)(.)\2\1/){
print "It matched the same after after y and d!\n"
}
- \1 匹配的第一个(.)
- \2 匹配的第二个(.)
**这个正则表达式的意思是匹配y后面的两个任意字符,再将这两个字符倒过来,yabba
就符合这个表达式。
2. 正则表达式的基本语法:
- "ab*":表示一个字符串有一个a后面跟着零个或若干个b。("a", "ab", "abbb",……);
- "ab+":表示一个字符串有一个a后面跟着至少一个b或者更多;
- "ab?":表示一个字符串有一个a后面跟着零个或者一个b;
- "a?b+$":表示在字符串的末尾有零个或一个a跟着一个或几个b。
也可以使用范围,用大括号括起,用以表示重复次数的范围。
- "ab{2}":表示一个字符串有一个a跟着2个b("abb");
- "ab{2,}":表示一个字符串有一个a跟着至少2个b;
- "ab{3,5}":表示一个字符串有一个a跟着3到5个b。
请注意,必须指定范围的下限(如:"{0,2}"而不是"{,2}")?;褂?,可能注意到了,'*','+'和'?'相当于"{0,}","{1,}"和"{0,1}"。
还有一个'|',表示“或”操作:
"hi|hello":表示一个字符串里有"hi"或者"hello";
"(b|cd)ef":表示"bef"或"cdef";
"(a|b)*c":表示一串"a""b"混合的字符串后面跟一个"c";
'.'可以替代任何字符,但是不包括换行符:
"a.[0-9]":表示一个字符串有一个"a"后面跟着一个任意字符和一个数字;
"^.{3}$":表示有任意三个字符的字符串(长度为3个字符);
方括号表示某些字符允许在一个字符串中的某一特定位置出现:
- "[ab]":表示一个字符串有一个"a"或"b"(相当于"a|b");
- "[a-d]":表示一个字符串包含小写的'a'到'd'中的一个(相当于"a|b|c|d"或者"[abcd]");
- "^[a-zA-Z]":表示一个以字母开头的字符串;
- "[0-9]%":表示一个百分号前有一位的数字;
- ",[a-zA-Z0-9]$":表示一个字符串以一个逗号后面跟着一个字母或数字结束。
也可以在方括号里用''表示不希望出现的字符,''应在方括号里的第一位。(如:"%[^a-zA-Z]%"表示两个百分号中不应该出现字母)。
3. 锚位
- /^正则表达式/:正则表达式在字符串开头
- /正则表达式$/:正则表达式在字符串结尾
- /\b正则表达式\b/:\b表示单词的开头或结尾
- /\B正则表达式\B/:\B表示不是单词的开头或结尾
4. 变量捕获
捕获变量使用2/$3…等特殊变量
if(/(\S+) (\S+), (\S+)/){
print "$1 $2 $3\n";#-->捕获到的三个变量
}
5. 正则表达式的特殊变量
- $& 所有正则表达式匹配到的内容
- $' 字符串中,正则表达式匹配到的内容,之后的内容
- $` 字符串中,正则表达式匹配到的内容,之前的内容
- $`$&$' 表示整个字符串,正则表达式调试最常用的方法是打印 $`<$&>$'
$a="abcd";
if($a=~/b/){
print "匹配上:{$`<$&>$'}\n";
}else{
print "no!\n";
}