先推荐两个测试正则网站:
正则表达式,大家都很熟悉,说白了就是一堆约定俗成的匹配规则,包含模式和可选的修饰符。创建一个正则表达式对象有两种语法。较长一点的语法:
regexp = new RegExp("pattern", "flags");
较短一点的语法,使用斜杠 "/":
regexp = /pattern/; // 没有修饰符
regexp = /pattern/gmi; // 伴随修饰符 g、m 和 i(后面会讲到)
斜杠 "/"
会告诉 JavaScript 我们正在创建一个正则表达式。它的作用类似于字符串的引号。new RegExp
可以动态传入参数创建正则。
本文的主要目的就是为了方便快速查找并理解需要的正则规则。
i
代表不区分大小写g
全部匹配u
根据 Unicode 属性匹配,使用 \p{...}/u
,详细属性查看let regexp = /\p{sc=Han}/gu; // 用来匹配中文
let str = `Hello Привет 你好 123_456`;
alert( str.match(regexp) ); // 你,好
m
多行模式,每行都会一次匹配(^ 每行会匹配一次开头 $ 同理)let str = `1st place: Winnie
2nd place: Piglet
33rd place: Eeyore`;
alert( str.match(/^\d+/gm) ); // 1, 2, 33
常用的字符类:
\d
数字\s
空格 space\w
单字符 word,包括字母数字下划线可以组合,比如:
let str = "test ES 6 AA"
let reg = /e\w\s\d/i
str.match(reg) // ["ES 6", index: 6, input: "test ES 6 AA", groups: undefined]
每个字符类都有反向类,代表 非xx
\D
非数字\S
非空格\W
非单字符let str = "+7(903)-123-45-67";
alert( str.replace(/\D/g, "") ); // 79031234567
.
匹配任意字符(换行符除外) "/ES./"
\b
查找目标“词”是否在边界,比如 /\bjava\b/
可以匹配 !java!
但是不能匹配 javac
^xx
表示以 xx 开头xx$
表示以 xx 结尾二者结合可以用以完全匹配
const time = "12:02"
let reg = /^\d\d:\d\d$/
// .test 可以测试是否匹配
reg.test(time) // true
空字符串 ''
,可以用 /^$/
匹配
[ \ ^ $ . | ? * + ( )
[abc]
表示 'a'、'b'、'c'
中的任意一个,也就是 或[a-z]、[1-5]
表示范围, [0-9A-F]
表示 0-9 或者 A-F, [\w-]
表示 字母 或 连字符 -
[^abcd]
表示匹配 a、b、c、d 以外的 字符 ,这种写法用以 排除a|b
相当于 [ab]
,我们可以这样使用:
gr(a|e)y
严格等同 gr[ae]y
。gra|ey
匹配 “gra” or “ey”。*
匹配 0~∞ 个 /\d*/
任意个数字+
匹配 1~∞ 个?
匹配 0 or 1 个,相当于 {0,1}
{n}
匹配 n 个, \d{3}
匹配三个连续数字,相当于 \d\d\d
{2,5}
匹配2 - 5位的数字{3,}
匹配 >= 3 个位数字看一个例子
let str = `"hi" some word "ok" aa`
let reg = /".+"/g
str.match(reg) //["hi" some word "ok"]
我们其实是想匹配出 ["hi","ok"]
,但是却匹配到了整句,这是因为 贪婪搜索 会先按顺序分别取匹配 " . +
"
的时候,匹配到第一个引号,此时匹配字符串是 "
.
的时候,匹配字符串是 "h
+
的时候,字符串变为了 "hi" some word "ok" aa
!因为后面所有的字符都符合 .+
的规则,即不包含换行的任意字符"
,发现已经匹配多了,找不到 "
,于是开始 回溯 ,知道回溯成为 "hi" some word "ok"
这就是 贪婪模式 。
再看一个例子:
let str = `123 456`
let reg1 = /\d+ \d+?/
let reg2 = /\d+ \d+/
str.match(reg1) // 123 4
str.match(reg2) // 123 456
在量词之后加上 ?
,即 .? +? ??
等,会变为 懒惰模式 ,他不会一次性完全匹配,而是在匹配到满足条件的第一位时就停止匹配。
举个例子:
let str = "gogogoaa"
let reg = /(go)+/
str.match(reg) // gogogo
很好理解,就是将多个字符算成一个整体进行匹配
接下来看几个例子
let str = "gogogoaa"
let reg = /(go)+/
str.match(reg) // gogogo
/[-.\w]+@([\w-]+\.)+[\w-]+/g
(xx)
被称为 组(group) 的概念,括号内的内容不仅匹配时被作为一个整体,并且组内匹配的对象会被返回:
/[-.\w]+@([\w-]+\.)+[\w-]+/g
返回的结果数组, [0]
的位置是正常全匹配返回的值,而 [1]
的位置是括号内匹配到到的值。我们可以用这个方法做 嵌套组 :
let str = `<group1 group2>`
let arr = str.match(/<((\w+)\s(\w+))>/)
console.log(arr[0]) //<group1 group2>
console.log(arr[1]) //group1 group2
console.log(arr[2]) //group1
console.log(arr[3]) //group2
let match = 'ac'.match(/a(z)?(c)?/)
alert( match.length ); // 3
alert( match[0] ); // ac(完全匹配)
alert( match[1] ); // undefined,因为 (z)? 没匹配项
alert( match[2] ); // c
上述都是在没有 g
标签时匹配的单个对象返回的数组,那么如果有 g
会返回多个对象的话,可以用 matchAll
来匹配:
let str = `<group1> <group2>`
let arr = Array.from(str.matchAll(/<(group\d)>/g))
arr[0][0] // <group1>
arr[0][1] // group1
arr[1][0] // <group2>
arr[1][1] // group2
注意, matchAll
返回的不是数组,而是一个可迭代的对象。
把上面的例子稍微修改
let str = `<group1 group2>`
let arr = str.match(/<(?<g0>(?<g1>\w+)\s(?<g2>\w+))>/)
let groups = arr.groups
console.log(arr[0]) //<group1 group2>
console.log(groups.g0) //group1 group2
console.log(groups.g1) //group1
console.log(groups.g2) //group2
我们可以通过 在括号后立即加上?<name>
的方式设置 group 名,通过返回数组的 groups
属性获取一个 group 对象
方法 str.replace(regexp, replacement)
用 replacement
替换 str
中匹配 regexp
的所有捕获组。这使用 $n
来完成,其中 n
是组号。例如,
let str = "John Bull";
let regexp = /(\w+) (\w+)/;
alert( str.replace(regexp, '$2, $1') ); // Bull, John
对于命名括号,引用为 $<name>
。例如,让我们将日期格式从 “year-month-day” 更改为 “day.month.year”:
let regexp = /(?<year>[0-9]{4})-(?<month>[0-9]{2})-(?<day>[0-9]{2})/g;
let str = "2019-10-30, 2020-01-01";
alert( str.replace(regexp, '$<day>.$<month>.$<year>') );
// 30.10.2019, 01.01.2020
我们需要找到带引号的字符串:单引号 '...'
或双引号 "..."
– 应匹配两种变体。然后我们有一句话 "She's the one!"
,这时候如果我们用 /['"](.*?)['"]/g
,则会匹配到 "She'
,显然不对
那么问题在于,我们怎么让正则记住我们某一个分组中捕获的内容 这时候可以使用 反向引用
let str = `He said: "She's the one!".`;
let regexp = /(['"])(.*?)\1/g;
alert( str.match(regexp) ); // "She's the one!"
这里的 \1
会找到第一个 group ,也就是 (['"])
匹配到的内容,也就是 "
,然后这个正则就相当于变成了 /(['"])(.*?)"/g
我们还可以用 \k<name>
的方式去引用:
let str = `He said: "She's the one!".`;
let regexp = /(?<g1>['"])(.*?)\k<g1>/g;
alert( str.match(regexp) ); // "She's the one!"
用法:
x(?=y)
仅当 x 后面是 y 的时候匹配let str = "1 turkey costs 30€";
alert( str.match(/\d+(?=€)/) ); // 30 (正确地跳过了单个的数字 1)
x(?!y)
仅当 x 后面不是 y 的时候匹配(?<=y)x
, 匹配 x
, 仅在前面是 y
的情况。(?<!y)x
, 匹配 x
, 仅在前面不是 y
的情况。断言仅仅是作为占位,不会匹配字符,比如
/q(?=u)i/
匹配'quit'
是会失败的,因为/q(?=u)/
只能匹配到q
而不是qu
如果我们想要捕捉整个环视表达式或其中的一部分,那也是有可能的。只需要将其包裹在另加的括号中。例如,这里货币符号 (€|kr)
和金额一起被捕获了:
let str = "1 turkey costs 30€";
let reg = /\d+(?=(€|kr))/; // €|kr 两边有额外的括号
alert( str.match(reg) ); // 30, €
str.match(regexp)
方法在字符串 str
中找到匹配 egexp
的字符。str.matchAll(regexp)
它主要用来搜索所有组的所有匹配项str.split(regexp|substr, limit)
使用正则表达式(或子字符串)作为分隔符来分割字符串。str.search(regexp)
返回第一个匹配项的位置,如果未找到,则返回 -1
str.replace(str|regexp, str|func)
用于搜索和替换的通用方法regexp.exec(str)
方法返回字符串 str
中的 regexp
匹配项。regexp.test(str)
查找匹配项,然后返回 true/false
表示是否存在。本文由哈喽比特于3年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/GlBI8Xo0SyOrHTxB4p10fQ
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。