javascript学习笔记2-正则表达式入门

材料:正则表达式30分钟入门教程  感谢作者deerchao    地址http://deerchao.net/tutorials/regex/regex.htm


定义: 正则表达式是记录文本规则的代码,可用于模式匹配和替换

常用元字符:   

点号 . 匹配除换行符意外的任意字符

\b  匹配单词的开始或结束

\w  匹配字母或数字或下划线           \ba\w*\b  以a开头的单词

\d  匹配数字

\s  匹配任意的空白符

^   匹配字符串的开始

$   匹配字符串的结束   ^\d{5,12}$    5到12位的数字


字符串转义:\ 查找元字符本身时使用   \.    查找 .

重复:


代码/语法 说明
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次

字符范围:  [ ]       [aeiou]  匹配任何一个英文原音字母

分支条件:  |       有几种规则,满足任意一种都当成匹配,注意各条件顺序,从左到右测试

分组:   ( )       可用于重复多个字符

反义:


代码/语法 说明
\W 匹配任意不是字母,数字,下划线,汉字的字符
\S 匹配任意不是空白符的字符
\D 匹配任意非数字的字符
\B 匹配不是单词开头或结束的位置
[^x] 匹配除了x以外的任意字符
[^aeiou] 匹配除了aeiou这几个字母以外的任意字符

后向引用:  每个分组会获得一个组号,通过组号重复该分组匹配的文本,\1表示分组1匹配的文本, \b(\w+)\b\s+\1\b 可以用来匹配 重复的单词 ,像 go go , 或者 kitty kitty 


分类 代码/语法 说明
捕获 (exp) 匹配exp,并捕获文本到自动命名的组里
(?<name>exp) 匹配exp,并捕获文本到名称为name的组里,也可以写成(?'name'exp)
(?:exp) 匹配exp,不捕获匹配的文本,也不给此分组分配组号
零宽断言 (?=exp) 匹配exp前面的位置
(?<=exp) 匹配exp后面的位置
(?!exp) 匹配后面跟的不是exp的位置
(?<!exp) 匹配前面不是exp的位置
注释 (?#comment) 这种类型的分组不对正则表达式的处理产生任何影响,用于提供注释让人阅读


注释:(?#comment)


  

        

你可能感兴趣的:(javascript学习笔记2-正则表达式入门)