\ 将下一个字符标记为一个特殊字符,或者一个原意字符,或者一个向后引用,或者一个八进制转义附符。例如,'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)。 |
|