国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

正則表達式完全學習手冊:菜鳥入門指導

原創
開發 前端
正則表達式看起來很嚇人,不容易讓人親近,但它的確很好用,可以很大程度上提高你的開發效率。本文從零開始介紹了應如何學習正則表達式。文中范例主要為JavaScript。

【51CTO精選譯文】正則表達式可以很恐怖,真得很恐怖。幸運的是,一旦記住每個符號所表達的意思,恐懼就會快速消退。如果你對正則表達式一無所知,正如文章標題,那你又就有很多東西要學了。下面讓我們馬上開始吧。

第一節:基礎學習

#t#想要高效地學習和掌握正則表達式的關鍵是花一天的時間記住所有符號。這可能是我所能提供的最好的建議。坐下來,做些記憶卡片,然后記住它們。以下為最常見的一些符號:
. - 匹配任意字符,換行符除外(如果 dotall 為 false)。
* - 該符號前面的字符,匹配 0 次或多次。
+ - 該符號前面的字符,匹配 1次或多次
? - 該符號前面的字符是可選的。匹配 0 次或 1 次。
\d - 匹配任何單個數字。
\w - 匹配任何一個字符(包括字母數字以及下劃線)。
[XYZ] - 匹配字符組中的任意一個字符,即 X、Y、Z 中的任意一個。
[XYZ]+ - 匹配字符組中的一個或多個字符。
$ - 匹配字符串結束的位置。
^ - 匹配字符串開始的位置。
[^a-z] - 當出現在字符類中時,^ 表示 NOT(非);對于該示例,表示匹配任何非小寫字母。

很悶吧,不過還是記住它們,記住之后你會知道好處的。

工具

你認為一個表達式是正確的,非常正確,但就是無法得到想要的結果,這時你可能會產生將頭發拔光的沖動。去下載 RegExr 桌面應用程序吧,這個對你是必不可少的,而且玩起來非常有趣的。它提供實時檢查,還有一個側邊欄,里面包含了每個字符的定義和用戶,非常詳細。

RegExr

第二節:正則表達式傻瓜教程:抓屏視頻

下一步是學習如何真正地使用這些符號。如果視頻是你的偏好,那你走運了。這里有五個課程的視頻教程,非常適合你:“正則表達式傻瓜教程”。

正則表達式視頻
(Jeffery Way:在這一系列視頻教程中,我將交給你如何在JavaScript和PHP中高效的使用正則表達式。我會假設你是從零開始。)

第三節:正則表達式和 JavaScript

本節為最后一節,我們來看看JavaScript 方法如何使用正則表達式。

1. Test()

這個方法接受單個字符串參數,然后返回一個布爾值,該值表明是否找到一個批評。如果你不需要對特定的匹配結果進行操作,比如,驗證用戶名,“test”方法已足夠完成這個任務。

示例

  1. var username = 'JohnSmith';    
  2. alert(/[A-Za-z_-]+/.test(username)); // returns true   

在上面的代碼中,我們首先聲明一個正則表達式,表示僅允許大寫或小寫字母、下劃線和連字符。將這些可接受的字符放在括號中,就指定了一個字符組。緊隨其后的 + 號表示我們想要正在尋找的是一個或多個前述字符組中的字符。然后使用該范式對變量“JohnSmith”進行測試。由于存在匹配,瀏覽器的顯示框中將顯示 true。

2. Split()

你可能對 split 方法已經很熟了。該方法接受單個正規表達式,表示在哪里進行“分割”。請注意,如果喜歡,你還可以使用字符串。

  1. var str = 'this is my string';    
  2. alert(str.split(/\s/)); // alerts "this, is, my, string"   

上面代碼中的 \s 表示單個空格,通過它,我們將字符串分割為一個數組。如果想要訪問某個特定的值,使用相應的索引即可。

  1. var str = 'this is my this string';    
  2. alert(str.split(/\s/)[3]); // alerts "string"   

3. replace()

可能你已經想到了,replace 方法可以用來將文本中的一部分(由字符串或正則表達式表示)替換為不同的字符串。

示例

如果想要將“Hello, World”改為“Hello, Universe”,可以使用下面的代碼:

  1. var someString = 'Hello, World';    
  2. someString = someString.replace(/World/, 'Universe');    
  3. alert(someString); // alerts "Hello, Universe"   

應留意的是,對于這個簡單的示例,我們本來可以簡單的使用.replace('World', 'Universe')。另外,使用 replace 方法不會自動重寫變量的值,我們必須將返回值再次分配給這個變量:someString。

示例 2

再舉一個例子,假設用戶要在我們的網站注冊一個賬號,我們可能想要提供一些基礎的安全預防措施。也許我們想要留下他們的用戶名,而刪除其他任何符號,引號、分號等等。對于 JavaScript 和正則表達式,執行這類任務是樁瑣碎的小事情。

  1. var username = 'J;ohnSmith;@%';    
  2. username = username.replace(/[^A-Za-z\d_-]+/, '');    
  3. alert(username); // JohnSmith;@%   

看到最后生成的顯示值,有人可能會想,上面的代碼有錯誤。事實并非如此。你仔細看看,會發現字母“J”后的分號被刪除了,正如我們所期望的那樣。為了通知引擎繼續搜索字符串查找更多匹配,我們可以做結束的斜杠后面直接添加一個“g”,這個修飾符或標記表示“global(全局)”。修改后的代碼如下所示:

  1. var username = 'J;ohnSmith;@%';    
  2. username = username.replace(/[^A-Za-z\d_-]+/g, '');    
  3. alert(username); // alerts JohnSmith   

現在,正則表達式搜索整個字符串,替換所有必要的字符。讓我們看看關鍵的表達式(.replace(/[^A-Za-z\d_-]+/g, '');),要注意,括號內的向上箭頭(即 ^)非常重要。當放在字符組中時,該符號表示“找到所有不是……”。現在回頭在看看這個代碼,它表示,找到所有不是字母、數字(由 \d 表示)、下劃線或連字符的符號;如果找到一個匹配,將其替換為空,事實上就是刪除該字符。

4. Match()

與test方法不同,match() 返回一個包含所有找到的批評的數組。

示例

  1. var name = 'JeffreyWay';    
  2. alert(name.match(/e/)); // alerts "e"   

上面的代碼將顯示一個字母“e”。但是,在字符串“JeffreyWay”中實際上包含2個 e。同樣,這次我們還是要使用修飾符“g”來聲明一個全局搜索。

  1. var name = 'JeffreyWay';    
  2. alert(name.match(/e/g)); // alerts "e,e"   

如果想要顯示數組中這些特定值中的一個,可以做括號中引用想要的索引。 

  1. var name = 'JeffreyWay';    
  2. alert(name.match(/e/g)[1]); // alerts "e"   

示例 2

讓我們看下一個示例,確保我們對它的理解是正確的。

  1. var string = 'This is just a string with some 12345 and some !@#$ mixed in.';    
  2. alert(string.match(/[a-z]+/gi)); // alerts "This,is,just,a,string,with,some,and,some,mixed,in"   

在這個正則表達式中,我們創建了一個范式,可匹配一個或多個大寫或小寫字母。這多虧了“i”修飾符。除外,我們還加上了“g”來聲明進行全局搜索。上面的代碼將顯示“This,is,just,a,string,with,some,and,some,mixed,in.”然后,如果想要獲取變量數組中這些值中的某一個,我們只需引用相應的索引即可。

  1. var string = 'This is just a string with some 12345 and some !@#$ mixed in.';    
  2. var matches = string.match(/[a-z]+/gi);    
  3. alert(matches[2]); // alerts "just"   

分割電子郵件地址

為了練習,我們試著將一個電子郵件地址(nettuts@tutsplus.com)分割為相應的兩部分:用戶名和域名,即 nettuts 和tutsplus。

  1. var email = 'nettuts@tutsplus.com';    
  2. alert(email.replace(/([a-z\d_-]+)@([a-z\d_-]+)\.[a-z]{2,4}/ig, '$1, $2')); // alerts "nettuts, tutsplus"   

如果對于正則表達式,你還是新手,上面的代碼可能會看起來有點嚇人。不用擔心,第一次看到都會感到“恐怖”。一旦將它分解為一個一個小子集,你會發覺其實非常簡單。下面讓我們一條一條進行分析:

  1. .replace(/([a-z\d_-]+)   

從中間開始看,我們要搜索任何字母、數字、下劃線或連字符,并且匹配一次或多次(+)。無論匹配是上面,我們想要訪問其值,所以將其放到括號中。這樣,我們稍后可以引用這個匹配的子集。

  1. @([a-z\d_-]+)   

緊接著前一個匹配,我們看到 @ 符號,然后是有一組一個或多個字母、數字、下劃線和連字符。同樣,我們將其放到括號內,以便稍后訪問。

  1. \.[a-z]{2,4}/ig,   

繼續找,我們看到一個點。因為在正則表達式中,句點可表示任何字符(有時換行符除外),因此必須使用“\”進行轉義。最后一部分是用于查找“.com”。我們知道,大多數域名,如果不是所有,其后綴為 2 到 4 個字符(com、edu、net、name 等等)。如果找到具體的范圍,我們可以先行使用更常規的符號,如 * 或 +。不過,我們在這里是將2個數字放到一個大括號中,分別表示最大值和最小值。

  1. '$1, $2')   

這個最后一部分表示replace方法的第二個參數,或者我們想要將匹配字符集替換為的對象。在這里,我們使用 $1 和 $2 分別來引用保存在第一個和第二個括號中的值。對于這個特定示例, $1 指向 nettuts,$2 指向 tutsplus。

創建自己的位置對象

作為最后的一個項目,我們將創建位置對象。位置對象向用戶提供有關當前頁面的信息:href、協議、地址、端口等。請注意,這里僅僅是作為練習之用。對于真正的網址,使用已有的位置對象即可。

首先我們創建位置函數,該函數接受單個參數,該參數表示我們想要“解碼”的網址,我們將其稱為“loc”。

  1. function loc(url) { }   

現在,我們可以按照下面的方式調用它,并傳入一個亂七八糟的 url:

  1. var l = loc('http://www.somesite.com?somekey=somevalue&anotherkey=anothervalue#theHashGoesHere');   

下一步,我們需要返回包含多個方法的對象。

  1. function loc(url) {    
  2.     return {    
  3.     
  4.     }    
  5. }   

搜索(search)

我們不會創建所有方法,但我們會模仿其中幾個。第一個是“search”。使用正則表達式,我們將要搜索 url 并返回查詢字符串中的所有內容。

  1. return {    
  2.     search : function() {    
  3.         return url.match(/\?(.+)/i)[1];     
  4.                // returns "somekey=somevalue&anotherkey=anothervalue#theHashGoesHere"  
  5.     }    
  6. }   

在上面的代碼中,我們使用了傳入的 url,試圖使用我們的正則表達式對其進行匹配。這個正則表達式在整個字符串中搜索問號,問號表示查詢字符串(querystring)的開始。在這個位置,我們需奧獲取其余的字符,這就是將(.+)放入括號的原因。最后,我們需要返回那個字符區塊,因此,使用[1]來定位它。

哈希值(Hash)

現在我們將創建一個方法,返回 url 的哈希值,或者 # 號后面的內容。

  1. hash : function() {    
  2.     return url.match(/#(.+)/i)[1]; // returns "theHashGoesHere"    
  3. },   

這次,我們搜索 # 號,同樣,使用括號獲取后面的字符,并使用 [1] 指向那個特定的子集。

協議

protocol 方法應返回,頁面所用的協議,可能你已經猜到了。這種協議通常為 http 或 https。

  1. protocol : function() {    
  2.     return url.match(/(ht|f)tps?:/i)[0]; // returns 'http:'    
  3. },   

這一個稍微更加復雜一點,因為存在幾個選項:http、https 和 ftp。

雖然可以使用這樣的格式 (http|https|ftp),但使用 (ht|f)tps? 更為簡潔,表示我們首先查找“ht”或“f”字符,下一步,匹配“tp”字符。最后的“s”是可選的,所以我們加了一個問號,表示問號前的字符出現零次或一次。

Href

這個是最后一個方法,返回頁面的 url。

  1. href : function() {    
  2.     return url.match(/(.+\.[a-z]{2,4})/ig); // returns "http://www.somesite.com"    
  3. }   

這里,我們對所有字符進行匹配,直到找到一個點號,這個點號后面有 2 - 4 個字符(表示 com、au、edu、name 等等)。重要的是意識到,對于這些表達式,我們可以寫得很復雜也可以寫得很簡單,這在于我們要求有多嚴格。

一個簡單的函數

  1. function loc(url) {    
  2.     return {    
  3.         search : function() {    
  4.             return url.match(/\?(.+)/i)[1];    
  5.         },    
  6.     
  7.         hash : function() {    
  8.             return url.match(/#(.+)/i)[1];    
  9.         },    
  10.     
  11.         protocol : function() {    
  12.             return url.match(/(ht|f)tps?:/)[0];    
  13.         },    
  14.         
  15.         href : function() {    
  16.             return url.match(/(.+\.[a-z]{2,4})/ig);    
  17.         }    
  18.     }    
  19. }   

使用上面這個函數,我們可以很簡單地顯示網址的每個部分:

  1. var l = loc('http://www.net.tutsplus.edu?key=value#hash');    
  2.     
  3. alert(l.href()); // http://www.net.tutsplus.com    
  4. alert(l.protocol()); // http:    
  5.     
  6. ...etc.   

就這樣。

原文:You Don’t Know Anything About Regular Expressions: A Complete Guide

作者:Jeffrey Way

責任編輯:yangsai 來源: 51CTO.com
相關推薦

2009-02-18 09:48:20

正則表達式Java教程

2016-11-10 16:21:22

Java 正則表達式

2010-02-24 17:13:47

2019-12-10 10:40:57

Python正則表達式編程語言

2010-03-01 15:51:59

Python則表達式

2009-08-17 13:56:28

C#正則表達式入門

2019-11-29 16:25:00

前端正則表達式字符串

2024-12-16 07:33:45

C#正則表達式

2010-07-22 09:12:05

Perl正則表達式

2018-09-27 15:25:08

正則表達式前端

2020-09-04 09:16:04

Python正則表達式虛擬機

2009-08-11 13:00:41

C#正則表達式

2009-08-07 14:31:40

.NET正則表達式基礎

2009-08-13 15:24:27

C#正則表達式

2009-09-08 09:32:13

正則表達式學習

2024-09-14 09:18:14

Python正則表達式

2010-03-25 18:25:36

Python正則表達式

2017-05-12 10:47:45

Linux正則表達式程序基礎

2019-07-17 15:45:47

正則表達式字符串前端

2009-09-16 18:19:34

正則表達式組
點贊
收藏

51CTO技術棧公眾號

老司机一区二区三区| 久久精品在线免费观看| 久久久久北条麻妃免费看| 视频在线91| 国产福利精品导航| 国产精品一区二区三区在线 | 美国三级日本三级久久99| 国产精品欧美日韩久久| 国产一区二区三区亚洲| 亚洲精品自产拍| 免费成人在线电影| 精品国产91九色蝌蚪| 国产激情小视频在线| 91成人免费网站| 国产剧情在线观看| 在线看不卡av| 国产三级视频在线看| 欧美日韩一区二区在线观看视频 | 里番在线观看网站| 欧美另类久久久品| 9191在线| 欧美成va人片在线观看| 影音先锋男人资源在线| 精品国产亚洲在线| 亚洲精品日产| 精品国产一区av| 国产精品久av福利在线观看| 91国在线精品国内播放| 欧美日韩导航| 国产综合福利在线| 国产视频一区三区| 亚洲欧洲日韩综合二区| 成人午夜碰碰视频| 日本肉体xxxx裸体xxx免费| 国产精品久久久久永久免费观看| 国产在线视频你懂| 在线观看免费视频综合| 羞羞网站在线免费观看| 亚洲品质视频自拍网| 国产一区二区三区精品在线观看| 91精品成人久久| 91精品国偷自产在线电影| 麻豆精品视频| 成人av资源在线观看| 色www免费视频| 91成人在线精品| 日韩电影大全网站| 欧洲成人免费aa| 亚洲中字在线| 青青在线免费观看视频| 精品久久久久久久大神国产| 一色桃子av在线| 久久成人精品一区二区三区| 日韩在线不卡| av不卡在线免费观看| 国产精品久久三| 免费网站成人| 欧美精品日韩三级| 欧美福利电影在线观看| 国产日韩第一页| 亚洲国产另类精品专区| 最新超碰在线| 91福利视频在线观看| 亚洲美女啪啪| av免费网站观看| 欧美日韩国产高清一区二区| www.国产精品| 亚洲aa中文字幕| 成人午夜在线免费| 国产在线视频福利| 欧美裸体xxxx极品少妇| 亚洲国产日本| 黄页免费观看| 日韩精品视频在线| 国产剧情在线观看一区| 黄色影视在线观看| 午夜欧美大尺度福利影院在线看| 性爽视频在线| 成人免费在线视频网站| 成人av免费网站| 免费观看在线午夜影视| 欧美激情网友自拍| 久久这里有精品15一区二区三区| 成年人视频网站| 国产一区二区日韩| 亚洲美女黄色| 一级一片免费视频| 久久精品99久久久久久久久 | 国产精品一区二区三区久久| 国产主播一区二区| 国产精品一级伦理| 午夜精品在线视频| 精品在线一区二区| 成年人免费在线视频| 81精品国产乱码久久久久久| 国产精选一区二区三区| 91大神在线网站| 国产精品亚洲精品| 国产精品高清亚洲| 欧美一级网址| 先锋影音日韩| 欧美日本精品一区二区三区| 国精一区二区| 日本不卡一区在线| 久久精品视频在线播放| 奇米色一区二区三区四区| 国产欧美日韩精品在线观看| 日本精品一区| 国产欧美高清视频在线| 精品剧情v国产在线观看在线| 国产桃色电影在线播放| 大量国产精品视频| 亚洲巨乳在线| 精精国产xxxx视频在线动漫| 精品电影一区二区三区 | 欧美一区二区在线观看| 精品国产三区在线| 污视频在线免费观看一区二区三区| 亚洲欧美日韩国产中文在线| 欧美另类激情| 日本在线视频www色| 精品久久人人做人人爽| 国产女优一区| 黄色网页在线免费看| 91免费版网站在线观看| 亚洲影院理伦片| 亚洲品质自拍| 日本免费视频www| 毛片精品免费在线观看| 国产宾馆实践打屁股91| 高清毛片在线观看| 日本在线成人一区二区| 日本福利一区二区| 亚洲国产不卡| 国产粉嫩一区二区三区在线观看 | 成人福利在线看| 亚洲wwww| 日韩av片在线看| 欧美插天视频在线播放| 91蜜桃网址入口| 我要色综合中文字幕| 久久久久久久少妇| 欧美激情精品久久久久久免费印度 | 国产盗摄精品一区二区酒店| 精品国产乱码久久久久久久软件 | 中文字幕乱码亚洲无线精品一区| 啦啦啦啦免费高清视频在线观看1| 57pao国产成人免费| 中文字幕亚洲成人| 成人在线丰满少妇av| 在线看a视频| 久久精品人人做人人爽电影| 精品日韩av一区二区| 国产美女精品人人做人人爽| 欧美网站免费| 毛片视频免费观看| 粉嫩av一区二区三区免费观看| 欧美一区二区福利视频| 狠狠色狠狠色综合日日91app| 日韩av中字| 日韩精品无码一区二区三区免费 | 伊人成综合网站| 国产 日韩 亚洲 欧美| 96精品视频在线| 色综合久久中文字幕| 视频在线在亚洲| 日韩成人在线一区| 欧美知名女优| 在线免费观看成人网| 久久久久久亚洲精品不卡| 欧美日韩一区二区三区 | 国产经典一区二区三区| 亚洲大胆美女视频| 中文字幕不卡在线播放| 欧美精品首页| av在线不卡精品| 国产中文字幕第一页| 欧美国产二区| 美女av一区二区三区| 黄色91在线观看| 日日夜夜免费精品| 精品视频一区二区三区| 国产在线视频资源| av日韩一区二区三区| 成人妇女免费播放久久久| 亚洲成人精品视频| 亚洲欧美日韩久久| 免费成人在线观看视频| 四虎5151久久欧美毛片| 成人video亚洲精品| 免费观看成人在线视频| 亚洲最大福利视频网| 中文字幕亚洲激情| 在线观看91精品国产入口| 91在线观看地址| 亚洲美女黄网| 久久影视三级福利片| 国产h片在线观看| 免费观看v片在线观看| 日韩精品xxxx|