1. 学习视频
https://www.bilibili.com/video/BV1pt41137qK?p=35&spm_id_from=pageDriver
https://www.bilibili.com/video/BV1pt41137qK?p=36&spm_id_from=pageDriver
2. 正则表达式-Regular expression 简称 RE
作用:用来简洁表达一组字符串的表达式。达到一行胜千言
例子1:PY+可以表示以PY为开头的字符串特征
‘PY’
‘PYY’ 正则表达式
‘PYYY’ <=等价于=> PY+
...
‘PYYY...’
例子2:
'PY' 开头
后续存在不多于10个字符 正则表达式
后续字符串不能是'P'或 ‘Y’ <=等价于=> PY[^PY]{0, 10}
'PYABC' √
'PYXYYZ' ✘
上述正则表达式的特点:
- 通用的字符串的表达框架
- 简洁表达一组字符串的表达式
- 针对字符串表达‘简洁’和‘特征’思想的工具
- 判断某字符串的特征归属
3. 正则表达式的常用操作符
操作符 | 说明 | 示例 |
---|---|---|
. | 表达任何单个字符 | |
[] | 字符串集,对单个字符给出取值范围 | [abc]表示a, b, c [a-z]表达a到z的单个字符 |
[^] | 非字符串集,对单个字符串给出排除范围 | [^abc]表示非a或b或c的单个字符 |
* | 前一个字符0次或无限次拓展 | abc* 表示 ab,abc,bacc,abccc等 |
+ | 前一个字符1次或无限次拓展 | abc+ 表示abc,abcc,abccc等,其中c出现1次或无数次 |
? | 前一个字符串0次或1次拓展 | abc? 表示 ab, abc |
{m} | 拓展前一个字符m次 | ab{2}c 表示abbc |
{m, n} | 拓展前一个字符m至n(含n) | ab{1,2}c 表示abc, abbc |
^ | 匹配字符串开头 | ^abc 表示abc且在一个字符串的开头 |
$ | 匹配字符串结尾 | abc$ 表示abc且在一个字符串的结尾 |
\d | 数字、等价于[0-9] | |
\w | 单词字符,等价于[A-Za-z0-9_] |
正则表达式的常用操作符
操作符 说明 示例
. 表达任何单个字符
[] 字符串集,对单个字符给出取值范围 [abc]表示a, b, c [a-z]表达a到z的单个字符
[^] 非字符串集,对单个字符串给出排除范围 [^abc]表示非a或b或c的单个字符
* 前一个字符0次或无限次拓展 abc* 表示 ab,abc,bacc,abccc等
+ 前一个字符1次或无限次拓展 abc+ 表示abc,abcc,abccc等,其中c出现1次或无数次
? 前一个字符串0次或1次拓展 abc? 表示 ab, abc
| 左右表达式任意一个 abc|def 表示abc、def
{m} 拓展前一个字符m次 ab{2}c 表示abbc
{m, n} 拓展前一个字符m至n(含n) ab{1,2}c 表示abc, abbc
^ 匹配字符串开头 ^abc 表示abc且在一个字符串的开头
$ 匹配字符串结尾 abc$ 表示abc且在一个字符串的结尾
() 分组标记,内部只能使用|操作符 (abc) 表示abc,(abc|def) 表示abc\def
\d 数字、等价于[0-9]
\w 单词字符,等价于[A-Za-z0-9_]
4. 实例
markdown的表格不支持 | 符号,容易乱掉,就不再表格
示例
正则表达式 对应字符串
P(Y|YT|YTH|YTHO)?N PN PYN PYYTN PYTHN PYYTHON
PY[TH]ON PYTON PYHON
PY[^TH]?ON PYON PYxON 即PY和ON之间不能存在TH
PYTHON+ PYTHON PYTHONN PYTHONNN...
PY{:3}N PN PYN PYYN PYYYN
^[A-Za-z]+$ 由26个字母组成的字符串
^[A-Za-z0-9]+$ 由26个字母和数字组成的字符串
^-?\d+$ 整数形式的字符串,其中符号为表示负数
^[0-9]*[1-9][0-9]*$ 正整数形式的字符串
[1-9]\d{5} 中国境内的邮政编码,6位
[\u4e00-\u9fa5] 匹配中文字符
\d{3}-\d{8}|\d{4}-\d{7} 国内电话号码,010-68913536
5. 如何设计IP地址的正则表达式
分析:IP 地址分4端,每段数值范围为0-255
v1.0版:不考虑范围,纯数字表达 \d+.\d+.\d+.\d+
v2.0版:约定数值长度,\d{1,3}.\d{1,3}.\d{1,3}.\d{1,3}
v3.0版:范围0~255如何界定:
00-99:[1-9]?\d
100-199:1\d{2}
200-249:2[0-4]\d
250-255:25[0-5]
即:[1-9]?\d|1\d{2}|2[0-4]\d|25[0-5].[1-9]?\d|1\d{2}|2[0-4]\d|25[0-5].[1-9]?\d|1\d{2}|2[0-4]\d|25[0-5].[1-9]?\d|1\d{2}|2[0-4]\d|25[0-5]
即:([1-9]?\d|1\d{2}|2[0-4]\d|25[0-5].){3}([1-9]?\d|1\d{2}|2[0-4]\d|25[0-5].)