当前位置: 首页 > news >正文

详解正则表达式中的?:、?= 、 ?! 、?<=、?<!

1、?: - 非捕获组

语法: (?:pattern)

作用: 创建一个分组但不捕获匹配结果,不会将匹配的文本存储到内存中供后续使用。

优势:

  • 提高性能和效率
  • 不占用编号(不会影响后续捕获组的编号)
  • 减少内存使用
// 使用捕获组
let regex1 = /(hello|hi) world/;
let match1 = "hello world".match(regex1);
console.log(match1);  // ["hello world", "hello"]

// 使用非捕获组
let regex2 = /(?:hello|hi) world/;
let match2 = "hello world".match(regex2);
console.log(match2);  // ["hello world"]

在以上例子中,除了完整匹配外,还捕获了"hello"。而在第二个例子中,只返回了完整匹配,不会捕获括号内的内容。

2、?= - 正向先行断言

语法: (?=pattern)

作用: 匹配后面跟着特定模式的位置,但不消耗这些字符(零宽度断言)。

特点:

  • 只断言位置,不匹配实际字符
  • 不会将断言的内容包含在最终匹配结果中
// 匹配后面是"元"的数字
let regex = /\d+(?=元)/;
let text = "价格是100元";
let match = text.match(regex);
console.log(match);  // ["100"]

// 匹配后面是闭标签的所有内容
let html = "<div>内容</div>";
let content = html.match(/.+(?=<\/div>)/);
console.log(content);  // ["<div>内容"]

在这个例子中,正向先行断言确保了特定内容存在于匹配之后,但不包含在匹配结果中。

3、?! - 负向先行断言

语法: (?!pattern)

作用: 匹配后面不跟着特定模式的位置。

特点:

  • 零宽度断言,只匹配位置
  • 用于排除某些模式
// 匹配不以数字结尾的单词
let regex = /\b\w+(?!\d)\b/g;
let text = "apple1 banana orange2";
let matches = text.match(regex);
console.log(matches);  // ["banana"]

// 匹配不后接元的数字
let priceText = "100元 200美元 300";
let numbers = priceText.match(/\d+(?!元)/g);
console.log(numbers);  // ["200", "300"]

 第一个例子匹配不以数字结尾的单词,第二个例子匹配后面不跟"元"的数字。

4、?<= - 正向后行断言

语法: (?<=pattern)

作用: 匹配前面有特定模式的位置。

特点:

  • 零宽度断言,查看匹配位置之前的内容
  • 不消耗字符,不包含在匹配结果中
// 匹配前面是货币符号的数字
let regex = /(?<=[$¥€£])(\d+(\.\d+)?)/g;
let text = "$100 ¥200 €300";
let matches = text.match(regex);
console.log(matches);  // ["100", "200", "300"]

// 匹配标签内的内容
let html = "<div>内容</div>";
let content = html.match(/(?<=<div>).*(?=<\/div>)/);
console.log(content);  // ["内容"]

第一个例子匹配前面有货币符号的数字,第二个例子匹配div标签内的内容。

5、?<! - 负向后行断言

语法: (?<!pattern)

作用: 匹配前面没有特定模式的位置。

特点:

  • 零宽度断言,排除特定前缀
  • 不消耗字符,只断言位置
// 匹配不在discount-后面的数字
let regex = /(?<!discount-)\d+/g;
let text = "price-100 discount-50 item-200";
let matches = text.match(regex);
console.log(matches);  // ["100", "200"]

// 匹配不以https://开头的URL
let urlRegex = /(?<!https:\/\/)www\.\w+\.\w+/g;
let urls = "http://www.example.com https://www.secure.com";
let httpUrls = urls.match(urlRegex);
console.log(httpUrls);  // ["www.example.com"]

第一个例子匹配不在"discount-"后面的数字,第二个例子匹配不以"https://"开头的URL。

相关文章:

  • 火语言RPA--增加减少时间
  • EN控制同步整流WD1020 ,3.0V-21V 的宽 VIN 输入范围,0.9V-20V 的宽输出电压范围
  • Android activity属性taskAffinity的作用
  • call、bind、apply
  • MySQL Error Log
  • 【第16届】蓝桥杯C++b组--记录一次被薄纱的心情
  • 艾伦·图灵:计算机科学与人工智能之父
  • 08-JVM 面试题-mk
  • KWDB创作者计划—KWDB认知引擎:数据流动架构与时空感知计算的范式突破
  • 20250412_代码笔记_CVRProblemDef
  • js 颜色转换分析
  • 【Flink运行时架构】核心组件
  • 优化方法介绍(一)
  • PCIe 5.0光学SSD原型问世!
  • 2025-4-11 情绪周期视角复盘(mini)
  • java -jar与java -cp的区别
  • 操作系统 ------ 五种IO模型
  • 前端工程化-包管理NPM-package.json 和 package-lock.json 详解
  • 小甲鱼第004讲:变量和字符串(下)| 课后测试题及答案
  • Git基础知识
  • 日本 男女做网站/友情链接也称为
  • 建设银行网站用户/宁波网站优化公司哪家好
  • 前几年做那些网站能致富/网络推广渠道排名
  • 邯郸有建网站吗哪个公司好些/网页广告怎么投放
  • 凡科网站教程/企业做推广有几种方式
  • 微网站建设包括哪些内容/sem优化软件选哪家