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)系作者
  • 序言:七十年代末明垢,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子市咽,更是在濱河造成了極大的恐慌痊银,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,548評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件施绎,死亡現(xiàn)場離奇詭異溯革,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)谷醉,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,497評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門致稀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人俱尼,你說我怎么就攤上這事抖单。” “怎么了遇八?”我有些...
    開封第一講書人閱讀 167,990評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵矛绘,是天一觀的道長。 經(jīng)常有香客問我刃永,道長蔑歌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,618評(píng)論 1 296
  • 正文 為了忘掉前任揽碘,我火速辦了婚禮次屠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘雳刺。我一直安慰自己劫灶,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,618評(píng)論 6 397
  • 文/花漫 我一把揭開白布掖桦。 她就那樣靜靜地躺著本昏,像睡著了一般。 火紅的嫁衣襯著肌膚如雪枪汪。 梳的紋絲不亂的頭發(fā)上涌穆,一...
    開封第一講書人閱讀 52,246評(píng)論 1 308
  • 那天,我揣著相機(jī)與錄音雀久,去河邊找鬼宿稀。 笑死,一個(gè)胖子當(dāng)著我的面吹牛赖捌,可吹牛的內(nèi)容都是我干的祝沸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,819評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼罩锐!你這毒婦竟也來了奉狈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,725評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤涩惑,失蹤者是張志新(化名)和其女友劉穎仁期,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體竭恬,經(jīng)...
    沈念sama閱讀 46,268評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蟀拷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,356評(píng)論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了萍聊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片问芬。...
    茶點(diǎn)故事閱讀 40,488評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖寿桨,靈堂內(nèi)的尸體忽然破棺而出此衅,到底是詐尸還是另有隱情,我是刑警寧澤亭螟,帶...
    沈念sama閱讀 36,181評(píng)論 5 350
  • 正文 年R本政府宣布挡鞍,位于F島的核電站,受9級(jí)特大地震影響预烙,放射性物質(zhì)發(fā)生泄漏墨微。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,862評(píng)論 3 333
  • 文/蒙蒙 一扁掸、第九天 我趴在偏房一處隱蔽的房頂上張望翘县。 院中可真熱鬧,春花似錦谴分、人聲如沸锈麸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,331評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忘伞。三九已至,卻和暖如春沙兰,著一層夾襖步出監(jiān)牢的瞬間氓奈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,445評(píng)論 1 272
  • 我被黑心中介騙來泰國打工鼎天, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留舀奶,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,897評(píng)論 3 376
  • 正文 我出身青樓训措,卻偏偏與公主長得像伪节,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子绩鸣,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,500評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

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