Nodejs正則表達式概述

1. 概念

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

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

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

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

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

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

????????說明:

????????????pattern 正則表達式

????????????flags 標識(修飾符)

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

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

? ? ? ? ? ? ? ? ? ?m 多行匹配(即在到達一行文本末尾時還會繼續(xù)尋找下一行中是否與正則匹配的項)

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

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

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

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

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

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

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

3. 元字符

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

特殊含義的元字符

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

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

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

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

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

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

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

????????????\ : 轉義字符

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

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

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

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

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

????????????$ : 限定結束位置 => 本身不占位置

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

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

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

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

????????????* : 0到多個

????????????+ : 1到多個

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

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

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

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

4. Nodejs中和正則相關的一些方法

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

示例:

????var str = 'hello';

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

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

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

示例:

????var str = 'tom287aaa879bbb666';

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

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

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

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

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

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

標識符 g 作用

????var str = 'abc123cba456aaa789';

????var reg = /\d+/g;? //此時加了標識符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

注意:

????每次調用exec方法時,捕獲到的字符串都不相同

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

????當未開始捕獲時,這個值為0。

????如果當前次捕獲結果為null。那么lastIndex的值會被修改為0.下次從頭開始捕獲。

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

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

????如果正則表達式?jīng)]有標識符 g 則exec與match功能一樣的

????如果正則表達式有標識符 g 則exec與match有明顯區(qū)別

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

????如果想用exec來達到同樣的效果需要執(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. 正則的特性 - 貪婪性 與 懶惰性

貪婪性

所謂的貪婪性就是正則在捕獲時,每一次會盡可能多的去捕獲符合條件的內容。

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

懶惰性

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

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

示例:

????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ōu)先級

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

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

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

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

\ : 轉義符

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

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

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

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

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

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

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

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