重学JS-012 --- JavaScript算法与数据结构(十二)正则表达式

文章目录

正则表达式

正则表达式通常简称为 "regex" 或 "regexp",是帮助程序员匹配、搜索和替换文本的模式。正则表达式功能强大,使用了大量特殊字符。

正则表达式标志

i 表达式忽略大小写

g 全局匹配 (Global),查找所有匹配项,而不是在找到第一个匹配项后就停止。

复制代码
const helpRegex = /please help/i;  与字符串 please help 匹配的正则表达式,忽略大小写
msg.match(helpRegx); //
helpRegex.test(msg);  // return bool

string.match()

字符串有一个 .match() 方法,它接受正则表达式作为参数并确定字符串是否与该表达式匹配。

.test() vs .match()

.test() 与.match()不同,.test() 返回一个布尔值,指示字符串是否与模式匹配。

.filter()

.some() 接受一个回调函数,该函数应将数组中的一个元素作为参数。如果回调函数对数组中的至少一个元素返回true,.some() 方法将返回true。

复制代码
const arr = ["A", "b", "C"];
arr.some(letter => letter === letter.toUpperCase());

const helpRegex = /please help|assist me/i;  // 正则表达式
const denyList = [helpRegex];
const isSpam = (msg) => helpRegex.test(msg);  // .test()
const isSpam = (msg) => denyList.some(regex => regex.test(msg));  //.some()

正则 \[\]

\[\] 匹配里面的内容

/a+/ +出现1次多无数次

用 (a|b|c)​​ 匹配 ​​多个单词选项​​(如 hundred或 thousand)。

​​用 abc​​ 匹配 ​​单个字符选项​​(如 a-z匹配任意小写字母)。

标识符

? 匹配前面字符或组的零次或一次出现。

用 \s* 表达式替换第一个文字空格。

\s 字符类匹配空白,例如空格、制表符和换行符。

* 量词表示"匹配前一个字符 0 次或更多次"。

非捕获组

实际上并不需要捕获组中的匹配值,因此你可以将其转换为非捕获组。 这将允许你将字符组合在一起而不保留结果。

要在正则表达式中创建非捕获组,可以在组的左括号后添加 ?:。 例如,(?:a|b) 将匹配 a 或 b,但不会捕获结果。

相关推荐
_日拱一卒16 分钟前
LeetCode:46全排列
算法·leetcode·职场和发展
丷丩25 分钟前
MapLibre GL JS第38课:根据缩放级别改变建筑颜色
javascript·map·mapbox·maplibre gl js
剑挑星河月29 分钟前
31.下一个排列
java·算法·leetcode
凌波粒32 分钟前
LeetCode--98.验证二叉搜索树(二叉树)
算法·leetcode·职场和发展
Ameilide1 小时前
数据结构 树 二叉树
数据结构
Kurisu5751 小时前
深度拆解:从令牌桶到滑动窗口,高并发系统限流算法的数学本质与边界
java·网络·算法
哈泽尔都1 小时前
运动控制教学——5分钟学会力控算法(阻抗/导纳/力位混合)
c++·python·算法·决策树·贪心算法·机器人·gpu算力
WWW65261 小时前
代码随想录 打卡第四十七天
数据结构·算法·leetcode
cpp_25011 小时前
P10722 [GESP202406 六级] 二叉树
数据结构·c++·算法·题解·洛谷·树形结构·gesp六级
smj2302_796826521 小时前
解决leetcode第3948题字典序最大的MEX数组
python·算法·leetcode