1. 概念
    1.1 Regular Expression(正则表达式)主要用于搜索、过滤字符串,包括普通字符(如a-z)与特殊字符(元字符)。
    1.2 元字符
    ^:匹配字符串的头部
    $:匹配字符串的尾部
    ():标记子表达式的开始与结束
    *:匹配前面的子表达式0次或多次
    ?:匹配前面的子表达式0次或1次,或指明一个非贪婪限定符
    +:匹配前面的子表达式1尺或多次
    .:匹配除\n外的任何单字符
    1.3 运算符优先级
    |\| 转义符 |
    |(), (?: ), (?=), []|圆括号和方括号|
    | *, +, ?, {n}, {n,}, {n,m} | 限定符|
    | ^, $, \任何元字符、任何字符 | 定位点和序列(即:位置和顺序)|
    |||替换,“或"操作
    字符具有高于替换运算符的优先级,使得"m|food"匹配"m"或"food”。若要匹配"mood"或"food",请使用括号创建子表达式,从而产生"(m|f)ood"。|
    1.4 字符簇
    [a-z] //匹配所有的小写字母
    [A-Z] //匹配所有的大写字母
    [a-zA-Z] //匹配所有的字母
    [0-9] //匹配所有的数字
    [0-9.-] //匹配所有的数字,句号和减号
    [ \f\r\t\n] //匹配所有的白字符
  2. 用法
    2.1 ^
    ^表示字符串的开头,但它还有另外一个含义。当在一组方括号里使用^是,它表示"非"或"排除"的意思,常常用来剔除某个字符。还用前面的例子,我们要求第一个字符不能是数字:
    ^[^0-9][0-9]$
    2.2 匹配多个字符
    ^a{4}$aaaa
    ^a{2,4}$aa,aaa或aaaa
    ^a{2,}$包含多于两个a的字符串
    2.3 ()与[]
    (0-9) 匹配 '0-9′ 本身, [0-9] 匹配数字
    2.4 小试牛刀
    匹配以dx为开头的二级域名:
    www.dxa000s4441a.com
    ^www.dx(.*).com$
  3. 参考
    3.1 正则表达式
    http://www.runoob.com/regexp/regexp-example.html
10-05 19:38