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)


  

        

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值