【正则表达式】入门

参考视频:10分钟快速掌握正则表达式_哔哩哔哩_bilibili

这个网站用来测试写的正则表达式效果:regex101: build, test, and debug regex

示例:

限定符

? 表示前一个字符可有可无

比如这里输入:de?

匹配结果可以得到d和de

* 前一个字符出现0到无穷次

这里输入:com*

得到comm,co

+ 前一个字符出现一次以上

这里输入:com+

得到comm,相比上一个示例*少了结果co

{} 指定出现次数范围

写单个数字指定前一个字符出现几次

逗号隔开两个数字,表示范围

还可以省略一个数字,如:

限定多个字符

给字符串加个括号当作一个字符即可。

| 运算符

字符类

\]内放字符,代表搜索的字符只能包含这几个字符 ![](https://img-blog.csdnimg.cn/direct/79f49eeb997740fbbe9a18980555258d.png)还可以扩大到范围。![](https://img-blog.csdnimg.cn/direct/3fd918fb16404fad8987edfc87ef4860.png) 前面加上\^代表除了这块字符 ![](https://img-blog.csdnimg.cn/direct/3ba157f42a40424997ca4dc02a9db1e2.png) ## 元字符 \\d代表数字字符,等于\[0-9

\w代表包括下划线的数字和任何单词字符

\s代表空白字符

\D代表非数字字符

\W代表非单词字符

\S代表非空白字符

.代表任意字符,但不包含换行符

^匹配行首,$匹配行尾,

贪婪与懒惰匹配

这里我们写入<.+>会贪心匹配到所有字符

但是我们只想要得到<>里的内容以便处理数据时删去,要怎么办呢?

加上问好即可把贪婪匹配转化为懒惰匹配,<.+?>

从原来尽可能多的匹配,到尽可能少的匹配。

实例

查找RGB

RGB是#开头的6位十六进制表达式

#[a-fA-F0-9]{6}

匹配#,十六进制,花括号指定位数

但是这里#fffffffff也被统计进去了,加上\b表示字符末尾的边界。#[a-fA-F0-9]{6}\b

相关推荐
瞎某某Blinder3 小时前
DFT学习记录[4] 电子和空穴的有效质量计算全流程
python·学习
zhangfeng11334 小时前
Warmup Scheduler深度学习训练中,在训练初期使用较低学习率进行预热(Warmup),然后再按照预定策略(如余弦退火、阶梯下降等)衰减学习率的方法
人工智能·深度学习·学习
red_redemption6 小时前
自由学习记录(118)
学习
小猪佩奇TONY7 小时前
OpenCL 学习(5)---- OpenCL 内核和内核参数
学习
01二进制代码漫游日记7 小时前
自定义类型:联合和枚举(一)
c语言·开发语言·学习·算法
非凡ghost8 小时前
小X分身APP(手机分身类工具)
android·windows·学习·智能手机·软件需求
weixin_458872618 小时前
东华复试OJ每日3题打卡·复盘82~84
学习
昌兵鼠鼠9 小时前
LeetCode Hot100 哈希
学习·算法·leetcode·哈希算法
旖旎夜光9 小时前
哈希(14)(下)
数据结构·c++·学习
2401_8480097211 小时前
Redis零基础入门学习
数据库·redis·学习