学习正则(第四天)拆分阅读

简介: 学习正则(第四天)拆分阅读

前言:


对于正则我们学了一下基础的知识,但是已经用在项目中的正则表达式你都读的懂吗?读不懂的话是不是又不放心呢?如何把复杂的一串串的正则拆解成便于理解的形式就变得很重要了。


结构和操作符:


在正则表达式中操作符都体现在了结构中,就是又特殊字符和普通字符组成的整体。


结构:

正则表达式的结构包括:字符字面量,字符组,量词,锚,分组,选择分支,反向引用。


操作符:

名称 操作符 优先级
转义 \ 1
括号和方括号 (...),(?:...),(?=...),(?!...),[...] 2
量词限定符 {m},{m,n},{m,},?,*,+ 3
位置和序列 ^,$,\元字符,一般字符 4
管道符


场景分析:


整体匹配:


目标字符串:**abcd****bcde**

初次写出来的正则我猜会是这样/^abcd|bcde$/gm,通过管道符来分割成两个子模式,但是你看过下图后会发现合规的字符成功匹配,但是变种的字符串也被匹配了:

1.png

对于上面图片的问题,我们需要通过可视化来看一下,匹配abcd开头的字符和匹配bcde结尾的字符?

2.png

由于位置字符的优先级要高于管道符,所以我们需要使用更高优先级的括号来进行分组,调整后的正则表达式见下图:

3.png

在调试工具中再看一下最终的结果:

4.png


量词连缀:

目标字符串满足每个字符a,b,c其中之一,字符串连续长度为3或3的倍数。

这回你的正则会怎么写呢,会是下图中的这样吗?

5.png

很明显的看到这个加号出现的真不是时候,那多个3要怎么来表示呢?同样我们要用到括号(小括号):

6.png



元字符转义:

在正则中的元字符(特殊字符)如包括:^$.*+?|\/()[]{}=!:-。在需要匹配字符本身的时候就需要进行转义,转义字符为“\”,字符转义需按实际情况使用。

7.png



如何匹配字符串[abc]呢?

[abc] 在正则表达式中为一个字符组,表示目标字符为a,b,c中的一个,那我们如何匹配字符串[abc]呢?当然也是转义了:左括号转义后单个右括号不构成字符组,故不


会引发歧义,不需要转义。

8.png9.png


如何匹配字符串{3,5}呢?

同理需要转义处理,请看下图:

10.png


案例分析:



简易身份证正则表达式:

正则表达式:/^(\d{15}|\d{17}[\dxX])$/gm11.png

我们通过可视化分析得知,由于管道符的优先级最低,正则表达式被分成两个分支,由15个数字组成的第一个分支和由17个数字+一个数字或一个大写或小写X。


IPV4正则表达式:

正则表达式:/^((0{0,2}\d|0?\d{2}|1\d{2}|2[0-4]\d|25[0-5])\.){3}(0{0,2}\d|0?\d{2}|1\d{2}|2[0-4]\d|25[0-5])$/

12.png


似乎上面的这个可视化也很复杂是不是,我们再换一个工具来看一下分析结果:

13.png


第一步拆分:
  1. 整体的结构分成了两部分匹配3次第一个表达式;
  2. 匹配一次第二个表达式;
  3. 现在上面的可视化有点眉目了吧,由数字+组成的Group1,和仅有数字组成的Group2和Group3。

第二部拆分:
  1. 前后两个表达式内容一致,最后一个表达式不需要比配点,故分析一个表达式即可;
  2. 第一个分支:0~2个0+1位数字,匹配两位数字并前面补0;
  3. 第二个分支:0+2位数字,匹配2位数字并前面补0;
  4. 第三个分支:1+2位数字,匹配100~199;
  5. 第四个分支:2+0~4其中一个+一位数字,匹配200~249;
  6. 第五个分支:25+0~5其中一个数字,匹配250~255。


结语:


学习如逆水行舟,学习需积少成多,学习要坚持不懈。



相关文章
|
7月前
|
算法
leetcode代码记录(组合
leetcode代码记录(组合
26 0
|
7月前
|
算法 vr&ar 图形学
☆打卡算法☆LeetCode 139. 单词拆分 算法解析
☆打卡算法☆LeetCode 139. 单词拆分 算法解析
|
7月前
|
存储 自然语言处理 算法
☆打卡算法☆LeetCode 140. 单词拆分 II 算法解析
☆打卡算法☆LeetCode 140. 单词拆分 II 算法解析
|
7月前
|
数据可视化 前端开发 程序员
想要白嫖正则大全是吧?这一次给你个够!
想要白嫖正则大全是吧?这一次给你个够!
125 0
|
算法
代码随想录训练营day46| 139.单词拆分
代码随想录训练营day46| 139.单词拆分
|
Java
第五期:字符串的一些有意思的操作
第五期:字符串的一些有意思的操作
92 0
|
XML 数据可视化 前端开发
🍩想要白嫖正则是吧?这一次给你个够!
想要白嫖正则是吧?本篇就一次给你个够!先冲 100 个!(如果还觉得不够就评论反馈后再加,本篇持续更新加码!!)
|
前端开发 JavaScript
前端工作总结231-读懂每行代码
前端工作总结231-读懂每行代码
88 0
前端工作总结231-读懂每行代码
|
JavaScript 前端开发 索引
【重温基础】9.正则表达式
【重温基础】9.正则表达式
190 0