RegExp正则表达式基础

什么是正则表达式

假设我们有一个字符串:abc_efg_abc_3

现在想要匹配这个字符串的abc_3

你可以这样写:

$定位符:表示字符串末
/abc_3$/

更好的写法:

\d元字符:表示任意数字
/abc_\d$/

正则表达式用于对字符串模式匹配及检索替换

一个简单正则的表达式就像上面一样,虽然我们已经会写了,但是还没正式介绍正则的写法

如何创建正则

有两种创建正则的方法:

  • js风格
    • new RegExp(pattern [, flags])
  • perl风格
    • /pattern/[flags]

我们一般采用perl风格,简单明了。

有必要说明一下上面已经出现的一些概念:定位符,元字符,pattern(模式),标识(flags)

定位符

  • ^ 字符串的开始
  • $ 字符串的结束

元字符

罗列几个简单常用的:

  • . 查找单个字符,除了换行和行结束符。
  • \w 查找单词字符。
  • \W 查找非单词字符。
  • \d 查找数字。

标识flags

  • i 执行对大小写不敏感的匹配。
  • g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
  • m 执行多行匹配。

正则的方法

test方法reg.test(str),返回一个布尔值,如果匹配到了返回true

/abc_\d$/.test('abc_efg_abc_3')     // return true

exec方法reg.exec(str)

如果匹配成功,exec() 方法返回一个数组,并更新正则表达式对象的属性。返回的数组将完全匹配成功的文本作为第一项,将正则括号里匹配成功的作为数组填充到后面。

如果匹配失败,exec() 方法返回 null。

/a/.exec('ccc_a_b')     // return ['a']

这就是正则最简单的使用方法,但是还有其他的几个方法

正则的字符串方法

  • search 检索与正则表达式相匹配的值
  • match 找到一个或多个正则表达式的匹配
  • replace 替换与正则表达式匹配的子串
  • split 把字符串分割为字符串数组

正则实例:手机号

正确匹配一个11位的手机号码

一般手机号的网段有:13x,15x,17x,18x

/^(13\d|15\d|17[789]|18\d)\d{8}$/

量词:{8},表示8位
方括号[]:表示可选其中任意一个字符
或|:或者

量词

如果不加量词,默认一个

  • {8} 8个
  • {3,10} 3~10
  • {5,} 最少5个
  • + | {1,}大于等于1个
  • {0,}可以没有
  • ? | {0,1}有或者没有

方括号[]

  • [0-9] 0~9任意一个
  • [^0-9] 排除0~9
  • [a-z0-9A-Z] 任意数字,字母大小写

参考

猜你喜欢

转载自www.cnblogs.com/lostyu/p/regexp_base.html
今日推荐