分享

正则表达式

 陈峤joe 2017-08-03

\     将下一个字符标记为一个特殊字符,或者一个原意字符,或者一个向后引用,或者一个八进制转义附符。例如,'n'匹配字符"n"。'\n' 匹配一个换行符。序列'\\' 匹配 "\" 而 "\(" 则匹配 "("。 
^     匹配输入字符串开始的位置,如果设置了RegExp 对象的Multiline属性 ,^也匹配"\n"或'\r'之后的位置。
$     匹配输入字符串的开始位置,如果设置了 RegExp 对象的Multiline属性 ,$也匹配 "\n" 或'\r'之前的位置。
*    匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z" 或者 "zoo" 。等价{0,}。
+     匹配前面的子表达式一次或者多次 。例如 'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 'z'。 等价于 {1,} 。
?   匹配前面的子表达式零次或一次 。例如, "do(es)?" 可以匹配 "do" 或"does" 中的 "do" 。 ?等价于{0,1}。
{n}  n 是一个非负整数 。匹配确定的N次 。 例如,'0{2}', 不能匹配 'Bob'中的'0' ,但是能匹配 'food'中的两个'o'。
{n,} n是一个肺腑整数 。 至少匹配n次 例如, '0{2,}' 不能匹配 "Bob" 中的 'o' 但是可以匹配 'food' 中的两个 'foooooood'中的所有 'o' 。'0{1,}'等价于 'o+'。 '0{0,}'等价于 'o*'。
{n,m} m和n均为非负整数 其中 n<=m 。最少匹配n次 且最多匹配m次 例如, "o{1,3}" 将匹配 "foooooood" 中的前三个 o。 'o{0,1}'等价于 'o?'。 请注意在逗号和两个数之间不能有空格。
? 当该字符紧跟在任何一个其他限制符 (*,+,?,{n},{n,m})后面时 ,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串 'oooo','o+?'将匹配单个 'o' ,而 'o+' 将匹配所有的 'o'。
.  匹配除 "\n" 之外的任何单个字符。要匹配包括'\n'在内的任何字符,请使用像 "(.|\n)"的模式。
(pattern) 匹配pattern并获取这一匹配结果,所获取的匹配可以从产生的Mathces集合得到,在 VBSript 中使用SubMatches 集合,在JScript中则使用 $ 0……%9属性。 要匹配园括号字请使用 "\("或"|)"。
(?:pattern) 匹配不获取结果,也就是说这是一个非获取匹配,不进行存储供以后使用。这是在使用或字符 "(|)" 来组合一个模式的各个部分很有用。例如 "industr(?:y|es)" 就是一个比 "industry|industries" 更简略的表达式。
(?!pattern) 正向否定预查,在任何不匹配pattern的字符串开始处,查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如 "Windows(?!95|98|NT|2000)" 能匹配 "Windows3.1" 中的 "Windows".但不能匹配 "Windows2000"中的" Windows"。 预查不消耗字符,也就是说,在一个匹配发生之后,在最后一次匹配之后立即开始下一次匹配的搜搜,而不是从包含预查的字符自后开始。
(?<pattern) 反向肯定预查,与正向肯定预查类似,只是方向相反。例如, "(?<=95|98|NT|2000)Windows"能匹配 "2000windows" 中的 "Windows",但不能匹配 "3.1Windows"中的 "Windows"。
x|y 匹配 x或y 。
[xyz]   字符集合。匹配所包含的任意一个字符。例如  '[abc]' 可以匹配 'plain' 中的 'a'。
[^xyz]   负值字符集合。匹配所包含的任意一个字符,例如, '[^abc]' 可以匹配到 'plain' 中的 'p'。
[a-z]     字符范围。匹配制定范围内的任意字符。例如, '[a-z]' 可以匹配 'a' 到 'z'范围内任意小写字母字符。
[^a-z]   负值字符范围。匹配任何不在制定范围内的任意字符。例如,'[^a-z]'可以匹配任何不在 'a'到 'z' 范围内的任意字符。
\b       匹配一个单词边界,也就是指单词范围内的任意字符。例如, 'er\b'可以匹配 'never' 中的  'er' 但是不能匹配  'verb'中的  'er'。
\B       匹配非单子边界。'er\B' 能匹配 'verb'中的 'er',但不能匹配 'never' 中的 'er'。
\d       匹配一个数字字符。等价于 [0-9]。
\D      匹配一个非数字字符。等价于 [^0-9]。
\f      匹配一个换页符。等价于 \x0C 和 \cL。
\n       匹配一个换行符  。等价于 \x0a  和 \cJ。
\r       匹配一个换行符 。等价于 \x0d 和 \cM。
\s      匹配任何空白字符,包括空格,制表符,换页符等等。等价于 [\f\n\r\t\v]。
\S       匹配任何非空白字符。等价于 [^\f\n\t\v]。 
\t 匹配一个制表符。等价于 \x09 和\CK。
\v       匹配一个垂直制表符。等价于 \x0b和\cK。
\w       匹配包括下划线的任何单词字符。等价于 "[A-Za-z0-9_]"。
\W      匹配任何非单词字符。等价于 '[^A-Za-z0-9_]'。
\xn 匹配n,其中n为十六进制转义值。十六进制转义值必须为确定的两个数字长度。例如,'\x41' 匹配 'A'。 '/x041'则等价于 '\x04&1'。正则表达式中科院使用 ASCLL 编码。
\num 匹配num ,其中num是一个整数。对所获取匹配的引用。例如,'(.)\1' ,匹配两个连续的相同字符。
\n 匹配一个八进制转义值或一个向后引用。如果\n之前至少n个获取的子表达式,则n为向后引用。否则,如果n为八进制数字(0-7) ,则n为一个八进制转义值。
\nm 标识一个八进制转义值或一个向后引用。如果\nm之前至少有nm个获得子表达式,则nm为向后引用。如果\nm 之前至少有n个获取,则n为一个后跟文字m的向后引用。如果前面的条件都不满足,若n和m均为八进制数字(0-7),则匹配八进制转义值nm。
\nml 如果n为八进制数字(0-7) ,且m和l均为八进制数字(0-7) ,则匹配八进制转义值nml。
\un 匹配n,其中n是一个用四十个十六进制数字表示的Unicode字符。例如,\u00A9匹配版权符号(c)。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多