正则表达式

正则表达式

概念:

使用单个字符串来描述、匹配一系列符号符合某个句法规则的字符串。

`* : 任意长度的字符串

?:任意长度为1的字符串

元字符的概念

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

\w 匹配字母或数字或下划线或汉子

\s 匹配任意的空白符

\d 匹配数字

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

^ 匹配字符串的开始

$ 匹配字符串的结束

\W 匹配任意不是字母 S数字,下划线 ,汉字的字符

\S 匹配任意不是空白符的字符

\D 匹配任意非数字的字符

\B 匹配不是单子开头或结束的位置

[^x] 匹配除了x意外的任意字符

[^aeiou] 匹配除了aeiou这几个字母意外的任意字符

字符的转意

\ 进行正则转意

正则表达式中的集中重复模式

\ * 重复零次或更多次

\ + 重复一次或更多次

? 重复零次或一次

{n} 重复n次

{n,} 重复n次或更多次

{n,m} 重复n到m次

分支条件

用 | 把不同的规则分隔开

从左到右的测试每个条件,如果满足某个分支的话,就不用去管其他条件

0\d{2}-\d{8}|0\d{3}-\d{7}

字符类

[0-9] == \d

[a-z0-9A-Z] == \w

[&?.]

[aeiou]

正则表达式中的分组概念和贪婪与懒惰

分组:

将表达式进行做成子集

使用()进行分组

方便对match的字符串进行划分

(\d{1,3}.){3}\d{1,3}

分组的命名:(?exp)

(?:exp) 匹配exp,不捕获匹配的文本,也不给此分组分配组号

贪婪与懒惰
贪婪(尽可能多)

a.*b (aabab) -> aabab

懒惰(尽可能少)

a.*?b (aabab)-> aab


*? 重复人一次,但尽可能少重复

+? 重复1次或更多次,但尽可能少重复

?? 重复0此或1此,但尽可能少重复

{n,m}? 重复n到m此,但尽可能少重复

{n,}? 重复n次以上,但尽可能少重复

处理选项 RegexOptions

IgnoreCase 匹配时不区分大小写

Multiline 更改^ 和$ 的含义,使它们分别在任意一行的行首和行位匹配,而不仅仅在一行的行首和行尾匹配。在此模式下,$精确含义是 匹配\n之前的位置和以字符串结束前的位置

Singleline 更改.的含义,使它与每一个字符匹配 也包括换行符\n

IgnorePatternWhitespace忽略表达式中的非专意空白并启用由#标记的注释

ExplicitCapture 仅捕获已被显示明名的组

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值