正则表达式--《Core Python Applications Programmin...

原创
2013/10/03 09:54
阅读数 99

一、正则表达式,在这里就不多说了,下面先看下特殊符号

符号 描述 例子
匹配字符(\n除外) b.b
^ 匹配以什么开头,好像\A也是的 ^Dear
$ 匹配以什么结尾,好像\Z也是的 /bin/*sh$
* 匹配前面的出现过0次或者任意次 [A-Za-z0-9]*
+ 匹配前面的出现1次或者任意次,至少有一次 [a-z]+\.com
匹配前面的出现1次或者0次 goo?
{N} 匹配前面出现了N次 [0-9]{3}
{M,N} 匹配前面出现了M-N次,是一个范围 [0-9]{5,9}
[...] 中括号,匹配中括号中的任意一个 [aeiou]
[...x-y...] 匹配中括号中x-y中的任意一个 [0-9],[a-z]
[^...] 不匹配中括号中任意一个 [^aeiou]
(*|+|?|{})? 匹配所有的 .*?[a-z]
(....) 将括号中做为一组整体的去匹配 ([0-9]{3})?

二、特殊的字符

特殊字符 描述 例子
\d 匹配任意一个数字,与[0-9]一样,\D与\d相反,匹配任意一个非数字 data\d+.txt
\w 匹配任意的字母和数字,与[A-Za-z0-9]一样,\W与之相反 [A-Za-z]\w+
\s 匹配所有空白格,和[\n\t\r\v\f]一样,\S与之相反 of\sthe
\b 匹配单词的边界,\B与之相反 \bThe\b
\N 匹配前面出现的第N组 price:\16
\c 匹配特殊的字符c,也就是转意c \.,\\,\*
\A(|Z) 匹配以什么开头(\A)或者结尾(\Z),与^和$一样 \ADear

三、特殊的扩展的符号

特殊扩展符号 描述 例子
(?iLmsux) 插入一个或者多个特殊的“标记”参数到正则表达式中 (?x),(?im)
(?:...) 表示一个匹配不保存 (?:\w+\.)*
(?P<name>) 给一个组命名,只是这里用的是名字而不是数字id (?p<data>)
(?P=name) 匹配由(?P<name>)定义的组 (?p=data)
(?#...) 指定一个comment,其它的都忽略掉 (?#comment)
(?=...) 先行断言,可以匹配表达式前面的位置 (?=.com)
(?!...) 负向零宽断言 ,这个位置的“断言”取表达式的反值 (?!.com)
(?<=...) 后发断言,表示匹配表达式后面的位置 (?<=800-)
(?<!...) 负向零宽后发断言 (?<!192\.168\.
(?(id/name)Y|N) 条件匹配,如果group(name or id)存在,则是表的是Y,否则就是N (?(1)y|x)
    零宽断言:用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们像\b,^,$那样用于指定一个位置,这个位置应该满足一定的条件(即断言),因此它们也被称为零宽断言。 

    先行断言:表示匹配表达式前面的位置 
例如 [a-z]*(?=ing) 可以匹配cooking singing 中的cook与sing 

注意:先行断言的执行步骤是这样的先从要匹配的字符串中的最右端找到第一个ing(也就是先行断言中的表达式)然后 再匹配其前面的表达式,若无法匹配则继续查找第二个ing 再匹配第二个 ing前面的字符串,若能匹配 则匹配
例如:.*(?=ing) 可以匹配cooking singing 中的cooking sing 而不是 cook 

    后发断言:表示匹配表达式后面的位置 

例如(?<=abc).* 可以匹配abcdefg中的defg        

注意:后发断言跟先行断言恰恰相反 它的执行步骤是这样的:先从要匹配的字符串中的最左端找到第一个abc(也就是先行断言中的表达式)然后 再匹配其后面的表达式,若无法匹配则继续查找第二个abc 再匹配第二个abc后面的字符串,若能匹配 则匹配 
例如(?<=abc).* 可以匹配abcdefgabc中的defgabc 而不是abcdefg 

负向零宽断言 :
负向零宽断言 (?!表达式) 也是匹配一个零宽度的位置,不过这个位置的“断言”取表达式的反值,例如 (?!表达式) 表示 表达式 前面的位置,如果 表达式 不成立 ,匹配这个位置;如果 表达式 成立,则不匹配:同样,负向零宽断言也有“先行”和“后发”两种,负向零宽后发断言为 (?<!表达式) 
负向零宽后发断言(?<!表达式) 
负向零宽先行断言 (?!表达式) 
负向零宽断言要注意的跟正向的一样

Regex Pattern  Notation Definition
(?:\w+\.)*  Strings that end with a dot, like “google.”, “twitter.”,“facebook.”, but such matches are neither saved foruse nor retrieval later.
(?#comment)  No matching here, just a comment。
(?=.com)  Only do a match if “.com” follows; do not consumeany of the target string.
(?!.net)  Only do a match if “.net” does not follow.
(?<=800-)  Only do a match if string is preceded by “800-”, pre-sumably for phone numbers; again, do not consume the input string.
(<!192\.168\.)  Only do a match if string is not preceded by “192.168.”,presumably to filter out a group of Class C IP addresses.
(?(1)y|x)  If a matched group 1 (\1) exists, match against y;otherwise, match against x.

展开阅读全文
加载中
点击引领话题📣 发布并加入讨论🔥
打赏
0 评论
1 收藏
0
分享
返回顶部
顶部