JavaScript正則表達式

JavaScript 正則表達式

@(筆記)[正則表達式]

第一章 課程簡介

1-1 JS正則表達式簡介及應用

課程目標

-了解正則表達式的語法
-在IDE中使用正則表達式處理規則復雜的字符串查找,替換需求
-在JavaScript程序設計中使用正則表達式處理字符串
-Regular Expression使用單個字符串來描述,匹配一系列符合某個句法規則的字符串
-說簡單了就是按照某種規則去匹配符合條件的字符串


第二章 認識正則表達式

2-1 Reg Exp對象

Reg Exp對象

Javascript通過內置對象Reg Exp支持正則表達式
有兩種方法實例化Reg Exp對象
1.字面量

var reg = /\bis\b/g;
"He is a boy.This is a dog.Where is she?".replace =(reg,"IS");

返回值:

"He IS a boy.This IS a dog.Where IS she?"

2.構造函數

var reg = new RegExp("\\bis\\b","g");//構造函數中反斜線(\)需要轉意,因為反斜線本身是特殊字符
"He is a boy.This is a dog.Where is she?".replace =(reg,"IS");

返回值:

"He IS a boy.This IS a dog.Where IS she?"

修飾符

-g:global全文搜索,不添加,搜索到第一個匹配停止。
-i:ignore case忽略大小寫,默認大小寫敏感。
-m:multiple lines 多行搜索。

2-2 元字符

1.正則表達式由兩種基本字符類型組成
-原義文本字符
-元字符
2.元字符是正則表達式中有特殊含義的非字母字符
* + ? $ ^ . | \ () {} []

符號 含義
\t 水平制表符
\v 垂直制表符
\n 換行符
\r 回車符
\0 空字符
\f 換頁符
\cX 與X對應的控制字符(ctrl+X)

2-3 字符類

-一般情況下正則表達式一個字符對應字符串一個字符
-表達式ab\t的含義是 ●—"ab"—tab—●
-我們可以使用元字符[ ]來構建一個簡單的類
-所謂類似指符合某些特性的對象,一個泛指,而不是指特定的某個字符
-表達式[abc]把字符a或b或c歸為一類,表達會可以匹配這類的字符


例:

"a1b2c3d4".replace(/[abc]/g,"X");

返回值:

"X1X2X3d4";

字符類取反

-使用元字符^創建反向類/負向類
-反向類的意思是不屬于某類的內容
-表達式[^abc]表示不是字符a或b或c的內容

注意:
[abc]與[abc]的區別:

[^abc]的圖示為:

表示不是字符a或b或c的內容
^[abc]的圖示為:
表示以a或b或c開頭的內容
例:

  1. "a1b2c3d4".replace(/[^abc]/g,"X");
    返回值:

    "aXbXcXXX";

  2. "a1b2c3d4".replace(/^[abc]/g,"X");
    返回值:

    "X1b2c3d4";

2-4 范圍類

-正則表達式提供了范圍類
-我們可以使用[a-z]來鏈接連個字符表示,從a到z的任意字符
-這是一個閉區間,也就是包含a和z
[a-z]圖示:


例:

"a1b2c3d45ef9".replace(/[a-z]/g,"X");

返回值:

"X1X2X3X45XX9";

-在[ ]組成的類內部是可以連寫的[a-zA-Z]
[a-zA-Z]圖示如下:


匹配范圍類同時也匹配"-"怎么辦?
例:

"2017-09-21".replace(/[0-9-]/g,"X");

返回值:

"XXXXXXXXXX";

2- 5 預定義類及邊界

預定義類

-正則表達式提供了預定義類來匹配常見的字符

字符 等價類 含義
. [^\r\n] 除了回車符和換行符之外的字符
\d [0-9] 數字字符
\D [^0-9] 非數字字符
\s [\t\n\XOB\f\r] 空白符
\S [^\t\n\XOB\f\r] 非空白符
\w [a-zA-Z_0-9] 單字符(字母、數字、下劃線)
\W [^a-zA-Z_0-9] 非單字符

例:匹配一個ab+數字+任意字符的字符串

var reg = /ab\d./g;

圖示:


-正則表達式還提供了幾個常用的邊界匹配符

字符 含義
^ 以xxx開始,例:var reg = /^a/g;(區別[\d]、[\d])
$ 以xxx結束,例:var reg = /a$/g;
\b 單詞邊界
\B 非單詞邊界

2-6 量詞

字符 含義
出現零次或一次(最多出現一次)
+ 出現一次或多次(最少出現一次)
* 出現零次或多次(任意次)
{n} 出現n次
[n,m] 出現n到m次
{n,} 出現至少n次

2- 7 JavaScript正則貪婪模式與非貪婪模式

-貪婪模式:盡可能多的匹配(默認)
例:

"12345678".replace(/\d{3,6}/g,"X");

返回值:

"X78"

-非貪婪模式:讓正則表達式盡可能少的匹配,也就是說一旦成功匹配不再繼續嘗試就是非貪婪模式
-做法很簡單,在量詞后面加上 ? 即可
例:

"12345678".replace(/\d{3,6}?/g,"X");

返回值:

"XX78";

2-8 分組、或

-匹配字符串Byron連續出現3次的場景

var reg = /Byron{3}/g;

圖示為:


注意:量詞作用于前面緊挨著的字符,并不是前面整個單詞。
-使用()可以達到分組的功能,使用量詞作用于分組

var reg = /(Byron){3}/g;

圖示:


例:

"a1b2c3d4".replace(/([a-z]\d){3}/g,"X");

返回值:

"Xd4";

-使用 | 可以達到或的效果

var reg = /Byron | Casper/;

圖示:
var reg = /Byr(on | Ca)sper/;

圖示:


例:

"ByronCasper".replace(/Byron|Casper/g,"X");

返回值:

"XX";

反向引用("$")

例:把"2017-09-21"轉換成"09/21/2017"

"2017-09-21".replace(/(\d{4})-(\d{2})-(\d{2})/g,"$2/$3/$1");

返回值:

"09/21/2017";

圖示:

忽略分組

-不希望捕獲分組,只需要在分組內加上 ?: 就可以(分組括號內的最前面)

var reg = /(?:Byron).(ok)/;

圖示:

2-9 前瞻

-JavaScript正則表達式從文本頭部向文本尾部開始解析,文本尾部方向,成為"前"
-前瞻就是正則表達式匹配到規則的時候,向前檢查是否符合斷言后顧/后瞻方向相反
-JavaScript不支持后顧
-符合和不符合特定斷言成為肯定/正向匹配和否定/負向匹配

名稱 正則 含義
正向前瞻 exp(?=assert)
負向前瞻 exp(?!assert)
正向后顧 exp(?<=assert) JavaScript不支持
負向后顧 exp(?<!=assert) JavaScript不支持

例:

var reg = /\w(?=\d)/;

圖示:


例:

"#4g@b7^!".replace(/\w(?=\d)/g,"X");

返回值:

"#4g@X7^!";

2-10 對象屬性

-global:是否全文搜索,默認false
-ignore case:是否大小寫敏感,默認是false
-multiline:多行搜索,默認值是false
-lastIndex:是當前表達式匹配內容的最后一個字符的下一個位置
-source:正則表達式的文本字符串
例:

var reg1 = /\w/;     
var reg2 = /\w/gim;  
reg1.global;        //false
reg1.ignoreCase;    //false
reg1.multiline;     //false
reg2.global;        //true
reg2.ignoreCase;    //true
reg2.multiline;     //true
reg1.source;        //"\w"
reg2.source;        //"\w"(文本字符串不包含標識符)

2-11 text和exec方法

RegExp.prototype.test(str)

-用于測試字符串參數中是否存在匹配正則表達式模式的字符串
-如果存在返回true,否則返回false
例:

var reg1 = /\w/;
reg1.test("a");//true
reg1.test("$");//false
var reg2 = /\w/g;
reg2.test("ab");//true
reg2.test("ab");//true
reg2.test("ab");//false
reg2.test("ab");//true
reg2.test("ab");//true
reg2.test("ab");//false(lastIndex屬性原因導致)

RegExp.prototype.exec(str)

-使用正則表達式模式對字符串執行搜索,并將更新全局RegExp對象的屬性以反映匹配結果
-如果沒有匹配的文本則返回null,否則返回一個結果數組:
1.index聲明匹配文本的第一個字符的位置
2.input存放被檢索的字符串 string

非全局調用

-調用非全局的RegExp對象的exec( )時,返回數組
-第一個元素是與正則表達式想匹配的文本
-第二個是與RegExpObject的第一個子表達式相匹配的文本(如果有的話)
-第三個元素是與RegExp對象的第二個子表達式相匹配的文本(如果有的話),以此類推
例:

var reg1 = /\d(\w)\d/;
var ts = "1a2b3c4d5e";
var ret = reg1.exec(ts);
console.log(reg1.lastIndex + "\t" + ret.index + "\t" + ret.toString();//執行第一次
console.log(reg1.lastIndex + "\t" + ret.index + "\t" + ret.toString();//執行第二次

返回值:

0   0   1a2,a;//第一個0因為在非全局下lastIndex屬性不生效所以是0
0   0   1a2,a;//在非全局下無論執行多少次lastIndex屬性不生效都是0

(全局搜索)例:

var reg2 = /\d(\w)(\w)\d/g;
var ts = "1az2bb3cy4dd5ee";
while(ret = reg2.exec(ts)){
    console.log(reg2.lastIndex + "\t" + ret.index + "\t" + ret.toString());
}

返回值:

4   0   1az2,a,z;//全局搜索lastIndex生效
10  6   3cy4,c,y;//全局搜索lastIndex生效

2-12 字符串對象方法

String.prototype.search(reg/string)

-search( )方法用于檢索字符串中指定的子字符串,或檢索與正則表達式相匹配的子字符串
-方法返回第一個匹配結果index,查不到返回-1
-search( )方法不執行全局匹配,它忽略標志g,并且總是從字符串的開始進行檢索
例:

"a1b2c3d1".search("1");   //返回 1
"a1b2c3d1".search("10");  //沒找到返回 -1
"a1b2c3d1".search(2);     //輸入數字,自動轉化為正則即:/2/
"a1b2c3d1".search(/2/);   //返回 3

String.prototype.match(reg)

-match( )方法將檢索字符串,以找到一個或多個與regexp匹配的文本
-regexp是否具有標志g對結果影響很大

非全局調用

-如果regexp沒有標志g,那么match()方法就只能在字符串中執行一次
-如果沒有找到任何匹配文本,將返回null
-否則它將返回一個數組,其中存放了與它找到的匹配文本有關的信息
-返回數組的第一個元素存放的是匹配文本,而其余的元素存放的是與正則表達式的子表達式匹配的文本
-除了常規的數組元素之外,返回的數組還含有2個對象屬性
1.index聲明匹配文本的起始字符在字符串的位置
2.input聲明對stringObject的引用
例:

var reg1  = /\d(\w)\d/;
var ts = "$1a2b3c4d5e";
var ret = ts.match(reg1);
console.log(ret);
console.log(ret.index + "\t" + reg1.lastIndex);

返回值:

["1a2", "a", index: 1, input: "$1a2b3c4d5e"];//FireFox結果
1   0;//非全局調用下lastIndex屬性不生效所以是 0
全局調用

-如果regexp具有標志g則match( )方法將執行全局檢索,找到字符串中的所有匹配子字符串
1.沒有找到任何匹配的字符串,則返回null
2.如果找到了一個或多個匹配字符串,則返回一個數組
-數組元素中存放的是字符串中多有的匹配字符串,而且也沒有index屬性或input屬性
例:

var reg2  = /\d(\w)\d/g;
var ts = "$1a2b3c4d5e";
var ret = ts.match(reg2);
console.log(ret);
console.log(ret.index + "\t" + reg1.lastIndex);

返回值:

 ["1a2", "3c4"];
 undefined  0; // index屬性不存在 lastIndex未生效
String.prototype.split(reg)

-我們經常使用split方法把字符串分割為數組

"a,b,c,d".split(",");//["a","b","c","d"]

-在一些復雜的分割情況下我們可以使用正則表達式解決

"a1b2c3d".split(/\d/);//["a","b","c","d"]
String.prototype.replace

-String.prototype.replace(str,replaceStr)
-String.prototype.replace(reg,reolaceStr)
-String.prototype.replace(reg,function)

function參數含義

function會在每次匹配替換的時候調用,有四個參數
1.匹配字符串
2.正則表達式分組內容,沒有分組則沒有改參數
3.匹配項在字符串中的 index
4.原字符串
例(不帶分組的):

"a1b2c3d4e5".replace(/\d/g,function(match,index,origin){
    console.log(index);
    return parseInt(match) + 1;
});

返回值:

1;//本次匹配的字符串第一個字符的下標
3;//本次匹配的字符串第一個字符的下標
5;//本次匹配的字符串第一個字符的下標
7;//本次匹配的字符串第一個字符的下標
9;//本次匹配的字符串第一個字符的下標
"a2b3c4d5e6";

例(帶分組的):

"a1b2c3d4e5".replace(/(\d)(\w)(\d)/g,function(match,group1,group2,group3,index,origin){
    console.log(match);
    return group1 + group3;
});

返回值:

1b2;//本次匹配的字符串
3d4;//本次匹配的字符串
"a12c34e5";
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,967評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,273評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,870評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,742評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,527評論 6 407
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,010評論 1 322
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,108評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,250評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,769評論 1 333
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,656評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,853評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,371評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,103評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,472評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,717評論 1 281
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,487評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,815評論 2 372

推薦閱讀更多精彩內容