掃二維碼與項目經理溝通
我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯網交流
正則表達式是由英文詞語regular expression翻譯過來的,就是符合某種規(guī)則的表達式。正則表達式在軟件開發(fā)中應用非常廣泛,例如,找出網頁中的超鏈接,找出網頁中的email地址,找出網頁中的手機號碼,判斷輸入的內容是否全部是數字,是否滿足某種日期格式等等。

創(chuàng)新互聯公司主打移動網站、網站建設、成都網站建設、網站改版、網絡推廣、網站維護、域名申請、等互聯網信息服務,為各行業(yè)提供服務。在技術實力的保障下,我們?yōu)榭蛻舫兄Z穩(wěn)定,放心的服務,根據網站的內容與功能再決定采用什么樣的設計。最后,要實現符合網站需求的內容、功能與設計,我們還會規(guī)劃穩(wěn)定安全的技術方案做保障。
可以將正則表達式理解為一種對文字進行模糊匹配的語言,它用一些特殊的符號(稱為元字符)來代表具有某種特征的一組字符以及該組字符重復出現的次數。例如,對于正則表達式“\d{5}(-\d{4})?”,\d就是一個元字符,它表示一個數字字符,{5}表示緊靠它前面的元素項連續(xù)重復5次,\d和{5}的組合\d{5}就表示匹配任意連續(xù)的5個數字字符;-\d{4}匹配的是一個連字號(-)后加上4個任意的數字,(-\d{4})?表示連字號(-)和后面的4個數字可有可無。
對于整個正則表達式“\d{5}(-\d{4})?”,表示要么是5個連續(xù)的數字字符,要么是5個連續(xù)的數字后加上一個連字號(-)、再加上4個連續(xù)的數字組成的10個字符。正則表達式中的圓括號除了能將多個元素組合成一個可統(tǒng)一操作的組合項外,它所括起來的表達式部分還成為了一個子匹配(也叫子表達式),也就是說,我們可以用圓括號在一個長的正則表達式中劃分出子表達式。這樣,除了可以得到整個正則表達式的匹配結果外,還可以單獨得到每個子表達式部分所匹配的結果。
要靈活運用正則表達式,必須了解其中各種元字符的功能。元字符從功能上大致分為:限定符、選擇匹配符、分組組合和反向引用符、特殊字符、字符匹配符、定位符。
限定符用于指定其前面的字符或組合項連續(xù)出現多少次,下面是各種限定符及其含義:
默認情況下,正則表達式使用最長(也叫貪婪)匹配原則。當字符“?”緊隨任何其他限定符(*、+、?、{n}、{n,}、{n,m})之后時,匹配模式變成使用最短(也叫非貪婪)匹配原則。例如,在字符串“fooood”中,“fo+?”只匹配“fo”部分,而“fo+”匹配“foooo”部分。
選擇匹配符就是“|”字符,用于選擇匹配兩個選項之中的任意一個,選擇匹配符的優(yōu)先級低于任意字符,即“|”字符的兩個選項是它兩邊盡可能最大的表達式。例如,“chapter|section 1”匹配的是“chapter”或“section 1”,而不是“chapter 1”或“section 1”。
分組組合符就是將正則表達式中的某一部分內容組合起來的符號,反向引用符則是用于匹配前面的分組組合所捕獲到的內容。
(pattern) 將圓括號中的pattern部分組合成一個可統(tǒng)一操作的組合項和子匹配,每個捕獲的子匹配項按照它們在正則表達式模式中從左到右出現的順序存儲在緩沖區(qū)中。緩沖區(qū)從1開始編號,最多可存儲99個子匹配捕獲的內容。存儲在緩沖區(qū)中的子匹配捕獲的內容,可以在編程語言中被檢索,也可以在正則表達式中被反向引用。
\num 匹配編號為num的緩沖區(qū)所保存的內容,此處的 num 是一個標識特定緩沖區(qū)的一位或兩位十進制正整數,這種方式稱為子匹配的反向引用。例如,要匹配連續(xù)的5個相同的數字字符,如55555、11111等,需要使用(\d)\1{4}作為正則表達式文本,\1表示與前面的(\d)所捕獲的內容一樣,\1{4}則表示前面的(\d) 所捕獲的內容還連續(xù)出現4次。
字符匹配符用于指定該符號部分可以匹配多個字符中的任意一個。
正則表達式中使用多種方式來表示非打印字符和原義字符,這些方式都是以反斜杠字符(\)后緊跟其他轉義字符序列來表示的,其中的一些方式也可以表示普通字符。
定位符用于規(guī)定匹配模式在目標字符串中的出現位置。
在正則表達式中用到的一些元字符不再表示它原來的字面意義,如果要匹配這些具有特殊意義的元字符的字面意義,必須使用反斜扛(\)將它們轉義為原義字符,即將反斜杠字符(\)放在它們前面。需要進行轉義的字符有“$”、“(”、“)”、“*”、“+”、“.”、“[”、“]”、“?”、“\”、“/”、“^”、“{”、“}”、“|”。
下面列舉出了一些具有典型意義和用途的正則表達式模式文本:
(1)匹配空行:“^\s*$”
(2)匹配HTML標記:“<(\S+)(\s[^>]*)?>[\s\S]*<\/\1\s*>”。
(3)匹配email地址:“[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+”
(4)匹配兩個相同的相鄰單詞:“\b([a-z]+) \1\b”
(5)匹配IP地址:“^\d{1,2}|1\d\d|2[0-4]\d|25[0-5](\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])){3}$”
JavaScript中提供了一個名為RegExp的對象來完成有關正則表達式的操作和功能,每一條正則表達式模式對應一個RegExp對象實例。在JavaScript中,有兩種方式可以創(chuàng)建RegExp對象的實例:
(1)使用RegExp對象的顯示構造函數,語法為:new RegExp("pattern"[,"flags"])
(2)使用RegExp對象的隱式構造函數,采用純粹的文本格式:/pattern/[flags]
pattern部分為要使用的正則表達式模式文本,是必須的。在第一種方式中,pattern部分以JavaScript字符串的形式存在,需要使用雙引號或單引號引起來;在第二種方式中,pattern部分嵌套在兩個“/”字符之間,不能使用引號引起來。flags部分設置正則表達式模式的標志信息,是可選的,可以是以下標志字符的組合:
下面是在javascript程序中應用正則表達式的一些典型案例:
1.將一個字符串中的所有的兩位數字的十位和個位交換:
2.使用正則表達式驗證身份證和提取年月日:
說明:身份證要么是15位,要么是18位,前面的每位都為數字,最后一位可以為字母,從7位到第14位為出生年月。
請輸入身份證:
3.使用正則表達式去掉字符串兩端的所有空格:
說明:javascript中的字符串沒有去掉兩端空格的功能,可以用prototype屬性為String類擴 展一個trim方法,以后的String類都可以使用這個trim方法來去掉兩端的空格了。
- String.prototype.trim = function(){return this.replace(/^\s+|\s+$/g,"");};
- alert(1 + " aaa ".strip() + 2);
下面是在java程序中應用正則表達式的一些典型案例:
1. 判斷輸入的字符串是否是一個email地址:
- String content = "[email protected]";
- Pattern p = Pattern.compile(
- "[a-zA-Z0-9_-][\\.a-zA-Z0-9_-]*@[a-zA-Z0-9_-]+(\\.[a-zA-Z0-9_-]+)+");
- Matcher m = p.matcher(content);
- boolean b = m.matches();
- System.out.println(content + (b? "是":"不是" ) + "一個有效的Email地址");
2. 從一篇文檔中提取出所有的email地址:
- String content = "我的email是[email protected],你的email是[email protected]";
- Pattern p = Pattern.compile(
- "[a-zA-Z0-9_-][\\.a-zA-Z0-9_-]*@[a-zA-Z0-9_-]+(\\.[a-zA-Z0-9_-]+)+");
- Matcher m = p.matcher(content);
- while(m.find()){
- String email = m.group();
- //String email = content.substring(m.start(), m.end());
- System.out.println(email);
- }
3.通過一個正則表達式即可以將字符串“xx”替換成“xxFileName”,還可以將字符串“xx[n]”替換成“xxFileName[n]”:
- String content = "xx[n]"; //改為"xx"試試。
- Pattern p = Pattern.compile("\\[.+\\]$|$");
- Matcher m = p.matcher(content);
- String fileName = m.replaceFirst("FileName$0");
- //String fileName = content.replaceFirst("\\[.+\\]$|$", "FileName$0");
- System.out.println(fileName);
4.從一封html格式的中文簡歷中提取出簡歷人的性別:
說明:性別在簡歷中通常為如下形式:
另外,簡歷中的其他地方也可能出現“男”或“女”,例如,“參觀了女排的訓練”。
- String content = "
性別: 男 …參觀了女排的訓練";- Pattern p = Pattern.compile("[^\u4e00-\u9fa5]([男女])[^\u4e00-\u9fa5]");
- Matcher m = p.matcher(content);
- if(m.find()){
- System.out.println("應聘者的性別為:" + m.group(1));
- }
總之, 隨著互聯網的迅速發(fā)展,幾乎所有工具軟件和程序語言都支持正則表達式,所以正則表達式變得越來越強大和易于使用。本文從限定符和定位符等方面介紹了正則表達式,希望對你有幫助,如果有什么問題,希望大家可以指正。
轉載自程序員網校 [ http://www.it315.org/ ]
本文鏈接地址:http://www.it315.org/programjava/222.htm
【編輯推薦】

我們在微信上24小時期待你的聲音
解答本文疑問/技術咨詢/運營咨詢/技術建議/互聯網交流