JS常见正则方法整理

2024-09-05 11:58
文章标签 常见 方法 整理 js 正则

本文主要是介绍JS常见正则方法整理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

JS常见正则方法整理 目录

文章目录

  • 前言
  • 1. 使用测试方法 - `test`
  • 2. 同时用多种模式匹配文字字符串 - `x|y`
  • 3. 匹配时忽略大小写 - `/x/i`
  • 4. 提取匹配项 - `match`
  • 5. 全局匹配 - `/x/g`
  • 6. 用通配符`.`匹配任何内容 - `/hu./`
  • 7. 将单个字符与多种可能性匹配 - `[aiu]`
  • 8. 匹配字母表中的字母 - `[a-z]`
  • 9. 匹配字母表中的数字和字母 - `[0-9]`
  • 10. 匹配单个未指定的字符 - `[^a-z]`
  • 11. 匹配出现一次或多次的字符 - `/a+/g`
  • 12. 匹配出现零次或多次的字符 - `/a*/`
  • 13. 用惰性匹配来查找最小字符 - `/t[a-z]*?/`
  • 14. 匹配字符串的开头 - `/^a/`
  • 15. 匹配字符串的末尾 - `/xx$/`
  • 16. 匹配所有的字母和数字 - `/\w/`
  • 17. 匹配除了字母和数字的所有符号 - `/\W/`
  • 18. 匹配所有数字 - `/\d/g`
  • 19. 匹配所有非数字 - `/\D/`
  • 20. 限制可能的用户名 - `/xx+\d*$/i`
  • 21. 匹配空白字符 - `/\s/`
  • 22. 匹配非空白字符 - `/\S/`
  • 23. 指定匹配的上限和下限 - `/\d{3,5}/`
  • 24. 只指定匹配的下限 - `/\d{3,}/`
  • 25. 指定匹配的确切数量 - `/a{3}/`
  • 26. 检查全部或无 - `/colou?r/`
  • 27. 正向先行断言和负向先行断言 - `/q(?=u)/, /q(?!u)/`
    • `abc123 - /(?=\w{3,6})(?=\D*\d)/`和`abc123 - /(?!\d)/`
  • 28. 使用捕获组重用模式 - `/(\w+)\s\1/`
  • 29. 使用捕获组搜索和替换 - `string.replace(regex, 's')`


前言

  • 整理自FreecodeCamp

1. 使用测试方法 - test

  • JavaScript中有多种使用正则表达式的方法。测试正则表达式的一种方法是使用.test()方法。
  • .test()方法会把你编写的正则表达式应用到一个字符串(即括号内的内容),如果你的匹配模式成功匹配到字符,则返回true,反之,返回false。
let testStr = "freeCodeCamp";
let testRegex = /Code/;
testRegex.test(testStr);
// Returns true

2. 同时用多种模式匹配文字字符串 - x|y

  • 可以使用|操作符来匹配多个规则。
  • 此操作符匹配在它之前或之后的匹配模式。例如,如果你想匹配"yes""no",你需要的正则表达式是/yes|no/
  • 你还可以匹配多个规则,这可以通过添加更多的匹配模式来实现。这些匹配模式将包含更多的|操作符来分隔它们,比如/yes|no|maybe/

3. 匹配时忽略大小写 - /x/i

  • 匹配不同的英文字母大小写
  • 大小写(或者字母大小写)是大写字母和小写字母的区别。大写字母的例子有"A"、"B""C"。小写字母的例子有"a"、"b"和"c"
  • 你可以使用标志(flag)来匹配这两种情况。标志有很多,不过这里我们只关注忽略大小写的标志——i
  • 你可以通过将它附加到正则表达式之后来使用它。这里给出使用该标志的一个实例/ignorecase/i。这个字符串可以匹配字符串"ignorecase""igNoreCase""IgnoreCase"

4. 提取匹配项 - match

  • 可以使用.match()方法来提取你找到的实际匹配项。
"Hello, World!".match(/Hello/);
// Returns ["Hello"]
let ourStr = "Regular expressions";
let ourRegex = /expressions/;
ourStr.match(ourRegex);
// Returns ["expressions"]

5. 全局匹配 - /x/g

  • 若要多次搜寻或提取匹配模式,你可以使用g标志。
let repeatRegex = /Repeat/ig;
testStr.match(repeatRegex);
// Returns ["Repeat", "Repeat", "Repeat"]

6. 用通配符.匹配任何内容 - /hu./

  • 通配符.将匹配任何一个字符。通配符也叫dotperiod。你可以像使用正则表达式中任何其他字符一样使用通配符。例如,如果你想匹配"hug"、“huh”、“hut"和"hum”,你可以使用正则表达式/hu./匹配以上四个单词。
let humStr = "I'll hum a song";
let hugStr = "Bear hug";
let huRegex = /hu./;
humStr.match(huRegex); // Returns ["hum"]
hugStr.match(huRegex); // Returns ["hug"]

7. 将单个字符与多种可能性匹配 - [aiu]

  • 你可以使用字符集搜寻具有一定灵活性的文字匹配模式。字符集允许你通过把它们放在方括号([和])之间的方式来定义一组你需要匹配的字符串。
  • 例如,你想要匹配"bag"、"big"和"bug",但是不想匹配"bog"。你可以创建正则表达式/b[aiu]g/来执行此操作。[aiu]是只匹配字符"a"、"i"或者"u"的字符集。
let bigStr = "big";
let bagStr = "bag";
let bugStr = "bug";
let bogStr = "bog";
let bgRegex = /b[aiu]g/;
bigStr.match(bgRegex); // Returns ["big"]
bagStr.match(bgRegex); // Returns ["bag"]
bugStr.match(bgRegex); // Returns ["bug"]
bogStr.match(bgRegex); // Returns null

8. 匹配字母表中的字母 - [a-z]

  • 在字符集中,你可以使用连字符(-)来定义要匹配的字符范围。
    例如,要匹配小写字母a到e,你可以使用[a-e]
let catStr = "cat";
let batStr = "bat";
let matStr = "mat";
let bgRegex = /[a-e]at/;
catStr.match(bgRegex); // Returns ["cat"]
batStr.match(bgRegex); // Returns ["bat"]
matStr.match(bgRegex); // Returns null

9. 匹配字母表中的数字和字母 - [0-9]

  • 使用连字符(-)匹配字符范围并不仅限于字母。它还可以匹配一系列数字。
  • 例如,/[0-5]/匹配0和5之间的任意数字,包含0和5
  • 此外,还可以在单个字符集中组合一系列字母和数字。
let jennyStr = "Jenny8675309";
let myRegex = /[a-z0-9]/ig;
// matches all letters and numbers in jennyStr
jennyStr.match(myRegex);

10. 匹配单个未指定的字符 - [^a-z]

  • 要创建否定字符集,你需要在开始括号后面和不想匹配的字符前面放置插入字符(即^)
  • 例如,/[^aeiou]/gi匹配所有非元音字符。
  • 注意,字符.、!、[、@、/和空白字符等也会被匹配,该否定字符集仅排除元音字符。

11. 匹配出现一次或多次的字符 - /a+/g

  • 你可以使用+符号来检查情况是否如此。记住,字符或匹配模式必须一个接一个地连续出现。
  • 例如,/a+/g会在"abc"中匹配到一个匹配项,并且返回[“a”]。因为+的存在,它也会在"aabc"中匹 配到一个匹配项,然后返回["aa"]
  • 如果它是检查字符串"abab",它将匹配到两个匹配项并且返回["a", "a"],因为a字符不连续,在它们之间有一个b字符。最后,因为在字符串"bcd"中没有"a",因此找不到匹配项。

12. 匹配出现零次或多次的字符 - /a*/

  • 可以匹配出现零次或多次的字符,执行该操作的字符叫做asteriskstar,即*
let soccerWord = "gooooooooal!";
let gPhrase = "gut feeling";
let oPhrase = "over the moon";
let goRegex = /go*/;
soccerWord.match(goRegex); // Returns ["goooooooo"]
gPhrase.match(goRegex); // Returns ["g"]
oPhrase.match(goRegex); // Returns null

13. 用惰性匹配来查找最小字符 - /t[a-z]*?/

  • 在正则表达式中,贪婪匹配会匹配到符合正则表达式匹配模式的字符串的最长可能部分,并将其作为匹配项返回。
  • 另一种方案称为懒惰匹配,它会匹配到满足正则表达式的字符串的最小可能部分。
  • 你可以将正则表达式/t[a-z]*i/应用于字符串"titanic"。这个正则表达式是一个以t开始,以i结束,并且中间有一些字母的匹配模式。
  • 正则表达式默认是贪婪匹配,因此匹配返回为["titani"]。它会匹配到适合该匹配模式的最大子字符串。
  • 但是,你可以使用?字符来将其变成懒惰匹配。调整后的正则表达式/t[a-z]*?i/匹配字符串"titanic"返回["ti"]

14. 匹配字符串的开头 - /^a/

  • 正则表达式可以用于查找许多匹配项。它们还用于搜寻字符串中特定位置的匹配模式。
  • 在之前的挑战中,你使用字符集中的插入符号(^)来创建一个否定字符集,形如[^thingsThatWillNotBeMatched]。在字符集之外,插入符号用于字符串的开头搜寻匹配模式。
let firstString = "Ricky is first and can be found.";
let firstRegex = /^Ricky/;
firstRegex.test(firstString);
// Returns true
let notFirst = "You can't find Ricky now.";
firstRegex.test(notFirst);
// Returns false

15. 匹配字符串的末尾 - /xx$/

  • 你可以使用正则表达式的美元符号$来搜寻字符串的结尾。
let theEnding = "This is a never ending story";
let storyRegex = /story$/;
storyRegex.test(theEnding);
// Returns true
let noEnding = "Sometimes a story will have to end";
storyRegex.test(noEnding);
// Returns false

16. 匹配所有的字母和数字 - /\w/

  • 使用字符类,你可以使用[a-z]搜寻字母表中的所有字母。这种字符类是很常见的,它有一个缩写,但这个缩写也包含额外的字符。
  • JavaScript 中与字母表匹配的最接近的字符类是\w,这个缩写等同于[A-Za-z0-9_]它不仅可以匹配大小写字母和数字,注意,它还会匹配下划线字符(_)。
let longHand = /[A-Za-z0-9_]+/;
let shortHand = /\w+/;
let numbers = "42";
let varNames = "important_var";
longHand.test(numbers); // Returns true
shortHand.test(numbers); // Returns true
longHand.test(varNames); // Returns true
shortHand.test(varNames); // Returns true

17. 匹配除了字母和数字的所有符号 - /\W/

  • 你已经了解到可以使用缩写\w来匹配字母和数字[A-Za-z0-9_]。不过,有可能你想要搜寻的匹配模式与字母数字相反。
  • 你可以使用\W搜寻和\w相反的匹配模式。注意,相反匹配模式使用大写字母。此缩写与[^A-Za-z0-9_]是一样的。
let shortHand = /\W/;
let numbers = "42%";
let sentence = "Coding!";
numbers.match(shortHand); // Returns ["%"]
sentence.match(shortHand); // Returns ["!"]

18. 匹配所有数字 - /\d/g

  • 查找数字字符的缩写是\d,注意是小写的d。这等同于字符类[0-9],它查找0 到 9 之间任意数字的单个字符。
let numString = "Your sandwich will be $5.00";
let numRegex = /\d/g; // 修改这一行
let result = numString.match(numRegex).length;

19. 匹配所有非数字 - /\D/

  • 查找非数字字符的缩写是\D。这等同于字符串[^0-9],它查找不是 0 - 9 之间数字的单个字符。

20. 限制可能的用户名 - /xx+\d*$/i

  • 用户名中的数字必须在最后,且数字可以有零个或多个。
  • 用户名字母可以是小写字母和大写字母。
  • 用户名长度必须至少为两个字符。两位用户名只能使用字母。
let username = "JackOfAllTrades";
let userCheck = /[a-z][a-z]+\d*$/i; // 修改这一行
let result = userCheck.test(username);

21. 匹配空白字符 - /\s/

  • 你可以使用\s搜寻空格,其中s是小写
  • 此匹配模式不仅匹配空格,还匹配回车符、制表符、换页符和换行符,你可以将其视为与[\r\t\f\n\v]类似
let whiteSpace = "Whitespace. Whitespace everywhere!"
let spaceRegex = /\s/g;
whiteSpace.match(spaceRegex);
// Returns [" ", " "]

22. 匹配非空白字符 - /\S/

  • 使用\S搜寻非空白字符,其中S是大写。此匹配模式将不匹配空格、回车符、制表符、换页符和换行符。你可以认为这类似于字符类[^\r\t\f\n\v]
let whiteSpace = "Whitespace. Whitespace everywhere!"
let nonSpaceRegex = /\S/g;
whiteSpace.match(nonSpaceRegex).length; // Returns 32

23. 指定匹配的上限和下限 - /\d{3,5}/

  • 回想一下,你使用加号+查找一个或多个字符,使用星号*查找零个或多个字符。这些都很方便,但有时你需要匹配一定范围的匹配模式。
  • 你可以使用数量说明符指定匹配模式的上下限。数量说明符与花括号({})一起使用。你可以在花括号之间放两个数字,这两个数字代表匹配模式的上限和下限。
  • 例如,要在字符串"ah"中匹配仅出现3到5次的字母a,你的正则表达式应为/a{3,5}h/
let A4 = "aaaah";
let A2 = "aah";
let multipleA = /a{3,5}h/;
multipleA.test(A4); // Returns true
multipleA.test(A2); // Returns false//修改正则表达式ohRegex以匹配在"Oh no"中仅出现3到6次的字母h。
let ohStr = "Ohhh no";
let ohRegex = /Oh{3,6}\sno/i; // 修改这一行
let result = ohRegex.test(ohStr);

24. 只指定匹配的下限 - /\d{3,}/

  • 可以使用带有花括号的数量说明符来指定匹配模式的上下限。但有时候你只想指定匹配模式的下限而不需要指定上限。
  • 在第一个数字后面跟一个逗号即可。
  • 例如,要匹配至少出现3次字母a的字符串"hah",你的正则表达式应该是/ha{3,}h/
let A4 = "haaaah";
let A2 = "haah";
let A100 = "h" + "a".repeat(100) + "h";
let multipleA = /ha{3,}h/;
multipleA.test(A4); // Returns true
multipleA.test(A2); // Returns false
multipleA.test(A100); // Returns true

25. 指定匹配的确切数量 - /a{3}/

  • 可以使用带有花括号的数量说明符来指定匹配模式的上下限。但有时你只需要特定数量的匹配。
  • 要指定一定数量的匹配模式,只需在大括号之间放置一个数字。
  • 例如,要只匹配字母a出现3次的单词"hah",你的正则表达式应为/ha{3}h/
let A4 = "haaaah";
let A3 = "haaah";
let A100 = "h" + "a".repeat(100) + "h";
let multipleHA = /a{3}h/;
multipleHA.test(A4); // Returns false
multipleHA.test(A3); // Returns true
multipleHA.test(A100); // Returns false

26. 检查全部或无 - /colou?r/

  • 有时,你想要搜寻的匹配模式可能有不确定是否存在的部分。尽管如此,你还是想检查它们。
  • 为此,你可以使用问号?指定可能存在的元素。这将检查前面的零个或一个元素。你可以将此符号视为前面的元素是可选的。
  • 例如,美式英语和英式英语略有不同,你可以使用问号来匹配两种拼写。
let american = "color";
let british = "colour";
let rainbowRegex= /colou?r/;
rainbowRegex.test(american); // Returns true
rainbowRegex.test(british); // Returns true

27. 正向先行断言和负向先行断言 - /q(?=u)/, /q(?!u)/

  • 先行断言是告诉 JavaScript 在字符串中向前查找的匹配模式。当你想要在同一个字符串上搜寻多个匹配模式时,这可能非常有用。
  • 有两种先行断言:正向先行断言和负向先行断言。
  • 正向先行断言会查看并确保搜索匹配模式中的元素存在,但实际上并不匹配。正向先行断言的用法是(?=...),其中...就是需要存在但不会被匹配的部分。
  • 另一方面,负向先行断言会查看并确保搜索匹配模式中的元素不存在。负向先行断言的用法是(?!...),其中...是你希望不存在的匹配模式。如果负向先行断言部分不存在,将返回匹配模式的其余部分。
  • 尽管先行断言有点儿令人困惑,但是这些示例会有所帮助。
let quit = "qu";
let noquit = "qt";
let quRegex= /q(?=u)/;
let qRegex = /q(?!u)/;
quit.match(quRegex); // Returns ["q"]
noquit.match(qRegex); // Returns ["q"]

abc123 - /(?=\w{3,6})(?=\D*\d)/abc123 - /(?!\d)/

  • 先行断言的更实际用途是检查一个字符串中的两个或更多匹配模式。这里有一个简单的密码检查器,密码规则是 3 到 6 个字符且至少包含一个数字
let password = "abc123";
let checkPass = /(?=\w{3,6})(?=\D*\d)/;
checkPass.test(password); // Returns true//在正则表达式pwRegex中使用先行断言以匹配至少5个字符且有两个连续数字的密码。
let sampleWord = "astronaut";
let pwRegex = /(?=\w{5})(?=\D*\d+)/; // 修改这一行
let result = pwRegex.test(sampleWord);

28. 使用捕获组重用模式 - /(\w+)\s\1/

  • 本质是先匹配大字符串,再从其中分割出一个小的字符串。
  • 一些你所搜寻的匹配模式会在字符串中出现多次,手动重复该正则表达式太浪费了。有一种更好的方法可以指定何时在字符串中会有多个重复的子字符串。
  • 你可以使用捕获组搜寻重复的子字符串。括号(和)可以用来匹配重复的子字符串。你只需要把重复匹配模式的正则表达式放在括号中即可。
  • 要指定重复字符串将出现的位置,可以使用反斜杠(\)后接一个数字。这个数字从1开始,随着你使用的每个捕获组的增加而增加。这里有一个示例,\1可以匹配第一个组。
  • 下面的示例匹配任意两个被空格分割的单词
//在字符串上使用.match()方法将返回一个数组,其中包含它匹配的字符串及其捕获组
let repeatStr = "regex regex";
let repeatRegex = /(\w+)\s\1/;
repeatRegex.test(repeatStr); // Returns true
repeatStr.match(repeatRegex); // Returns ["regex regex", "regex"]//在正则表达式reRegex中使用捕获组,以匹配在字符串中仅重复三次的数字,
//每一个都由空格分隔。
let repeatNum = "42 42 42";
let reRegex = /^(\d+)\s\1\s\1$/; // 修改这一行
let result = reRegex.test(repeatNum);

29. 使用捕获组搜索和替换 - string.replace(regex, 's')

  • 搜索功能是很有用的。但是,当你的搜索也执行更改(或替换)匹配文本的操作时,搜索功能就会显得更加强大。
  • 可以使用字符串上.replace()方法来搜索并替换字符串中的文本。.replace()的输入首先是你想要搜索的正则表达式匹配模式,第二个参数是用于替换匹配的字符串或用于执行某些操作的函数。
let wrongText = "The sky is silver.";
let silverRegex = /silver/;
wrongText.replace(silverRegex, "blue");
// Returns "The sky is blue."
  • 还可以使用美元符号($)访问替换字符串中的捕获组。
"Code Camp".replace(/(\w+)\s(\w+)/, '$2 $1');
// Returns "Camp Code"let huhText = "This sandwich is good.";
let fixRegex = /(\w+).$/; // 修改这一行
let replaceText = "okey-dokey."; // 修改这一行
let result = huhText.replace(fixRegex, replaceText);

这篇关于JS常见正则方法整理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1138895

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

数论入门整理(updating)

一、gcd lcm 基础中的基础,一般用来处理计算第一步什么的,分数化简之类。 LL gcd(LL a, LL b) { return b ? gcd(b, a % b) : a; } <pre name="code" class="cpp">LL lcm(LL a, LL b){LL c = gcd(a, b);return a / c * b;} 例题:

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo