Nodejs正則表達(dá)式概述

1. 概念

正則表達(dá)式描述了一種字符串匹配的模式,可以用來檢查一個(gè)字符串是否含有某種子串、將匹配的子串做替換或者從某個(gè)字符串中取出符合某個(gè)條件的子串的等。

2.創(chuàng)建正則表達(dá)式

方式一:字面量創(chuàng)建方式

? ? ? ? ? ? ?var reg = /pattern/flags

方式二:構(gòu)造函數(shù)實(shí)例創(chuàng)建方式

? ? ? ? ? ? ?var reg = new RegExp(pattern, flags)

????????說明:

????????????pattern 正則表達(dá)式

????????????flags 標(biāo)識(shí)(修飾符)

????????????修飾符主要有:

? ? ? ? ? ? ? ? ? ?i 忽略大小寫匹配

? ? ? ? ? ? ? ? ? ?m 多行匹配(即在到達(dá)一行文本末尾時(shí)還會(huì)繼續(xù)尋找下一行中是否與正則匹配的項(xiàng))

? ? ? ? ? ? ? ? ? ? g 全局匹配(模式應(yīng)用于所有的字符串),而非在找到第一個(gè)匹配項(xiàng)時(shí)停止

????????????注意:

????????????字面量創(chuàng)建方式特殊含義的字符不需要轉(zhuǎn)義,實(shí)例創(chuàng)建方式需要轉(zhuǎn)義

????????????示例:

????????????var reg1 = new RegExp('\d'); // 表示的 d (如果需要\,必須轉(zhuǎn)義\\)

????????????var reg2 = new RegExp('\\d'); // 表示的 \d

????????????var reg3 = /\d/; // 表示的 \d

3. 元字符

元字符主要分為代表特殊含義的字符與代表次數(shù)的量詞元字符

特殊含義的元字符

????????????\d : 0-9之間的任意一個(gè)數(shù)字? \d只占一個(gè)位置

????????????\w : 數(shù)字,字母 ,下劃線 0-9 a-z A-Z _

????????????\s : 空格或者空白等

????????????\D : 除了\d

????????????\W : 除了\w

????????????\S : 除了\s

????????????. : 除了\n之外的任意一個(gè)字符

????????????\ : 轉(zhuǎn)義字符

????????????| : 或者

????????????() : 分組

????????????\n : 匹配換行符

????????????\b : 匹配邊界 字符串的開頭和結(jié)尾 空格的兩邊都是邊界 => 不占用字符串位數(shù)

????????????^ : 限定開始位置 => 本身不占位置

????????????$ : 限定結(jié)束位置 => 本身不占位置

????????????[a-z] : 任意字母 []中的表示任意一個(gè)都可以

????????????[^a-z] : 非字母 []中^代表除了

????????????[abc] : abc三個(gè)字母中的任何一個(gè) [^abc]除了這三個(gè)字母中的任何一個(gè)字符

次數(shù)的量詞元字符

????????????* : 0到多個(gè)

????????????+ : 1到多個(gè)

????????????? : 0次或1次 可有可無

????????????{n} : 正好n次;

????????????{n,} : n到多次

????????????{n,m} : n次到m次

4. Nodejs中和正則相關(guān)的一些方法

- reg.test(str)? //用來驗(yàn)證字符串是否符合正則 符合返回true 否則返回false

示例:

????var str = 'hello';

????var reg = /\w+/; // 模式:匹配1到多個(gè)的數(shù)字、字母、下劃線

????console.log(reg.test(str)); // true

- reg.exec() //用來捕獲符合規(guī)則的字符串

示例:

????var str = 'tom287aaa879bbb666';

????var reg = /\d+/;

????console.log(reg.exec(str));

????// 返回?cái)?shù)組中 [0:"287", index:3, input:"tom287aaa879bbb666"]

????// 0 : "123" 表示我們捕獲到的字符串

????// index: 3 表示捕獲開始位置的索引

????// input: tom287aaa879bbb666 表示原有的字符串

標(biāo)識(shí)符 g 作用

????var str = 'abc123cba456aaa789';

????var reg = /\d+/g;? //此時(shí)加了標(biāo)識(shí)符g

????console.log(reg.lastIndex) // lastIndex : 0

????console.log(reg.exec(str)) //? ["123", index: 3, input: "abc123cba456aaa789"]

????console.log(reg.lastIndex) // lastIndex : 6

????console.log(reg.exec(str)) // ["456", index: 9, input: "abc123cba456aaa789"]

????console.log(reg.lastIndex) // lastIndex : 12

????console.log(reg.exec(str)) // ["789", index: 15, input: "abc123cba456aaa789"]

????console.log(reg.lastIndex) // lastIndex : 18

????console.log(reg.exec(str)) // null

????console.log(reg.lastIndex) // lastIndex : 0

注意:

????每次調(diào)用exec方法時(shí),捕獲到的字符串都不相同

????lastIndex :這個(gè)屬性記錄的就是下一次捕獲從哪個(gè)索引開始。

????當(dāng)未開始捕獲時(shí),這個(gè)值為0。

????如果當(dāng)前次捕獲結(jié)果為null。那么lastIndex的值會(huì)被修改為0.下次從頭開始捕獲。

????而且這個(gè)lastIndex屬性還支持人為賦值。

- str.match(reg) 如果匹配成功,就返回匹配成功的數(shù)組,如果匹配不成功,就返回null

????如果正則表達(dá)式?jīng)]有標(biāo)識(shí)符 g 則exec與match功能一樣的

????如果正則表達(dá)式有標(biāo)識(shí)符 g 則exec與match有明顯區(qū)別

????當(dāng)全局匹配時(shí),match方法會(huì)一次性把符合匹配條件的字符串全部捕獲到數(shù)組中,

????如果想用exec來達(dá)到同樣的效果需要執(zhí)行多次exec方法。

示例:

????var str = 'abc123cba456aaa789';

????var reg = /\d+/g;

????console.log(reg.exec(str)); // ["123", index: 3, input: "abc123cba456aaa789"]

????console.log(str.match(reg)); // ["123", "456", "789"]

- str.replace() 正則去匹配字符串,匹配成功的字符去替換成新的字符串

語法:str.replace(reg,newStr);

示例:

????var str = 'b123bc456d';

????var res = str.replace(/\d/g,'Q')

????console.log(res) // "bQQQbcQQQd" 將所有的數(shù)字替換字符Q

5. 正則的特性 - 貪婪性 與 懶惰性

貪婪性

所謂的貪婪性就是正則在捕獲時(shí),每一次會(huì)盡可能多的去捕獲符合條件的內(nèi)容。

如果我們想盡可能的少的去捕獲符合條件的字符串的話,可以在量詞元字符后加?

懶惰性

懶惰性則是正則在成功捕獲一次后不管后邊的字符串有沒有符合條件的都不再捕獲。

如果想捕獲目標(biāo)中所有符合條件的字符串的話,我們可以用標(biāo)識(shí)符g來標(biāo)明是全局捕獲

示例:

????var str = '123aaa456';

????var reg = /\d+/;? //只捕獲一次,一次盡可能多的捕獲

????var res = str.match(reg)

????console.log(res)? // ["123", index: 0, input: "123aaa456"]

????reg = /\d+?/g; //解決貪婪性、懶惰性

????res = str.match(reg)

????console.log(res)? // ["1", "2", "3", "4", "5", "6"]

6. 正則運(yùn)算符的優(yōu)先級(jí)

正則表達(dá)式從左到右進(jìn)行計(jì)算,并遵循優(yōu)先級(jí)順序,這與算術(shù)表達(dá)式非常類似。

相同優(yōu)先級(jí)的會(huì)從左到右進(jìn)行運(yùn)算,不同優(yōu)先級(jí)的運(yùn)算先高后低。

下面是常見的運(yùn)算符的優(yōu)先級(jí)排列

依次從最高到最低說明各種正則表達(dá)式運(yùn)算符的優(yōu)先級(jí)順序:

\ : 轉(zhuǎn)義符

(), (?:), (?=), []? => 圓括號(hào)和方括號(hào)

*, +, ?, {n}, {n,}, {n,m}? => 量詞限定符

^, $, \任何元字符、任何字符

|? ? ? => 替換,"或"操作

字符具有高于替換運(yùn)算符的優(yōu)先級(jí),一般用 | 的時(shí)候,為了提高 | 的優(yōu)先級(jí),我們常用()來提高優(yōu)先級(jí)

如: 匹配 food或者foot的時(shí)候 reg = /foo(t|d)/ 這樣來匹配

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • --------------------------正則的作用--------------------------...
    G_whk閱讀 751評(píng)論 1 5
  • 初衷:看了很多視頻、文章,最后卻通通忘記了,別人的知識(shí)依舊是別人的,自己卻什么都沒獲得。此系列文章旨在加深自己的印...
    DCbryant閱讀 4,228評(píng)論 0 20
  • 前言 作為一個(gè)程序員,要出去裝逼,手中必備的技能就是正則表達(dá)式。程序員的正則表達(dá)式,醫(yī)生的處方和道士的鬼畫符,都是...
    Layzimo閱讀 681評(píng)論 0 6
  • 明天休息日出去散散心,一些事一些人讓我內(nèi)心有點(diǎn)壓抑,人太簡(jiǎn)單也是錯(cuò),說得多不如沉默,想太多心會(huì)難過。每個(gè)人都有自己...
    LoveYoga喵喵閱讀 139評(píng)論 0 0
  • 類的構(gòu)造 person.java 訪問控制 friendly不是關(guān)鍵字,只是一種默認(rèn)修飾符的稱謂。 p1:MyCl...
    Demons_96閱讀 348評(píng)論 0 0

友情鏈接更多精彩內(nèi)容