正则表达式

正则表达式

开发工具与关键技术:Visual Studio 2015
作者:徐晶旗
撰写时间:2019年5月6日 

之前学的正则表达式,就被它那种可以把复杂的东西简易化而且能实现同等的效果吸引了,那正则表达式到底是什么?在编写处理字符串的程序或网页时,经常会有查找符合某些复杂的字符串的需要。正则表达式就是用于描述这些规则的工具。换句话说,正则表达式就是记录文本规则的代码。下面就来简单的介绍一下正则表达式

一、元字符
元字符:即为有特定含义的字符,常见的元字符如下

常用的元字符
代码 说明
. 匹配除换行符以外的任意字符
\w 匹配字母或数字或下划线或汉字
\s 匹配任意的空白符
\d 匹配数字
\b 匹配单词的开始或结束
^ 匹配字符串的开始(在集合字符里[^a]表示非(不匹配)的意思
$ 匹配字符串的结束

(1). 匹配任何任意字符 例如 . 可以匹配 1,n,*,+,- ,等

(2)\d\w\s 匹配第一个字符为数字,第二个字符为字母或数字、或下划线或汉字,第三字符为空格的字符串 例如:11 ,2a , 1_

(3)^\d\d\d$ 匹配三个全部都为数字的字符串 例如: 123,456,789

     还可以用于验证输入的字符串是否符合qq(身份证号)的验证 :

     例如:^\d{8}$ 匹配8位数字的qq号,^\d{18}&匹配18位均为数字的身份证号

二、反义字符
反义字符:多用于查找除某个字符以外其他任意字符均可以的情况

常用的反义字符如下:

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

(1)\W 匹配除字母、数字、下划线、汉字以为的字符形如 +,-,*

(2)\S 匹配除空格以外的任意字符形如:1,* ,)

三、限定字符
限定字符多用于重复匹配次数

常用的限定字符如下

  • 重复零次或更多次
  • 重复一次或更多次
    ? 重复零次或一次
    {n} 重复n次
    {n,} 重复n次或更多次
    {n,m} 重复n到m次

(1)\d* 匹配重复0次或多次数字 例如:可能为空 或 任意数字 (2,3。。。。)

(2)\d+ 匹配重复1次或多次数字 例如:可能为1个或多个数字 1,23,234,2345,…

(3)\d? 匹配重复次个或者一次数字 例如:可能为空或者任意的一个数字(1,2,…)

(4)\d{6}匹配重复6次数字 例如:123456

(5)\d{5,}匹配重复至少5次数字 例如:12345,123456,22334,345678 …

(6)^\d{8,10}$ 匹配重复8-10次数字 例如:12345678,123456789,1234567890 …

当正则表达式中包含能接受重复的限定符时,通常的行为是(在使整个表达式能得到匹配的前提

下)匹配尽可能多的字符。以这个表达式为例:a.b,它将会匹配最长的以a开始,以b结束的

字符串。如果用它来搜索aabab的话,它会匹配整个字符串aabab。这被称为贪婪匹配。

有时,我们更需要懒惰匹配,也就是匹配尽可能少的字符。前面给出的限定符都可以被转化为懒

惰匹配模式,只要在它后面加上一个问号?。这样.?就意味着匹配任意数量的重复,但是在能使整

个匹配成功的前提下使用最少的重复。

通过下面这段代码可以看出:最长匹配和最短匹配的差别通过这段代码可以看出:最长匹配和最短

匹配的差别,一个匹配尽可能多的字符,一个匹配尽可能少的字符。一般正则表达式引擎默认都

是最长匹配的,如果我们想要最短匹配,那么可以在数量修饰符后面添加一个?变成最短匹配。

/注释1*/ var name = “zly”; /注释2*/
var name = “zly”;

如果我们要删除所有注释,那么应该采用最短匹配,否则var name=“zly”;这段代码会被替换掉。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值