[.net 面向對象程序設計進階] (2) 正則表達式 (一) 快速入門

[.net 面向對象程序設計進階] (2) 正則表達式 (一) 快速入門javascript

1. 什麼是正則表達式?php

1.1 正則表達式概念html

正則表達式,又稱正則表示法,英文名:Regular Expression(簡寫爲regexregexpRE),是計算機科學的一個重要概念。他是用一種數學算法來解決計算機程序中的文本檢索、區配等問題。java

1.2 正則表達式語言支持 python

     正則表達式其實與語言無關,在不少語言中都提供了支持 ,包括最經常使用的腳本語言Javascript。固然C#語言也絕不例外的提供了很好的支持。
     正則表達式語法支持狀況以下表:正則表達式

命令或環境算法

.express

[ ]編程

^數組

$

\( \)

\{ \}

?

+

|

( )

vi

 

 

 

 

 

Visual C++

 

 

 

 

 

awk

 

 

sed

 

 

 

 

delphi

 

python

 

 

 

 

java

 

 

 

 

javascript

 

php

 

 

 

 

 

perl

 

C#

 

 

1.3 正式表達式的應用 

在進階系列文章的開始就介紹正則表達式,是由於他很是經常使用,在咱們開發應用程序的時候,須要對輸入內容進行格式校驗,須要對複雜的字符中找出規律檢索出咱們想要的部分。對於剛接觸的人來講,比較晦澀難懂,當你讀完本篇之後,就會感受正則表達式並非什麼複雜的東西。

所以使用正則表達式,能夠幫助咱們解決如下問題:

A.檢索: 能夠經過正則表達式,從字符串中獲取咱們想要的特定部分。

B.匹配:給定的字符串是否符合正則表達式的過濾邏輯 

下面幾種應用場景,都特別適合正則表達式來解決

A.在論壇或博客中發貼時過濾敏感的字詞

B.在應用軟件中進行輸入格式校驗時

C.對一段複雜文本中進行有規則的替換時

D.將一段複雜文本按必定的規則變爲另外一種形式時 

下面咱們會介紹正則表達式的基礎知識。

2. 正則表達式的組成

一個正則表達式就是由普通字符以及特殊字符(稱爲元字符)組成的文字模式。該模式描述在查找文字主體時待匹配的一個或多個字符串。正則表達式做爲一個模板,將某個字符模式與所搜索的字符串進行匹配。

下面,我把特殊字符,也就是元字符列舉一下

元字符

描述

\

將下一個字符標記爲一個特殊字符、或一個原義字符、或一個向後引用、或一個八進制轉義符。例如,「\\n」匹配\n「\n」匹配換行符。序列「\\」匹配「\」「\(」則匹配「(」。即至關於多種編程語言中都有的轉義字符的概念。

^

匹配輸入字符串的開始位置。若是設置了RegExp對象的Multiline屬性,^也匹配「\n」「\r」以後的位置。

$

匹配輸入字符串的結束位置。若是設置了RegExp對象的Multiline屬性,$也匹配「\n」「\r」以前的位置。

*

匹配前面的子表達式任意次。例如,zo*能匹配「z」「zo」以及「zoo」*等價於{0,}

+

匹配前面的子表達式一次或屢次(大於等於1次)。例如,「zo+」能匹配「zo」以及「zoo」,但不能匹配「z」+等價於{1,}

?

匹配前面的子表達式零次或一次。例如,「do(es)?」能夠匹配「do」「does」中的「do」?等價於{0,1}

{n}

n是一個非負整數。匹配肯定的n次。例如,「o{2}」不能匹配「Bob」中的「o」,可是能匹配「food」中的兩個o

{n,}

n是一個非負整數。至少匹配n次。例如,「o{2,}」不能匹配「Bob」中的「o」,但能匹配「foooood」中的全部o「o{1,}」等價於「o+」「o{0,}」則等價於「o*」

{n,m}

mn均爲非負整數,其中n<=m。最少匹配n次且最多匹配m次。例如,「o{1,3}」將匹配「fooooood」中的前三個o「o{0,1}」等價於「o?」。請注意在逗號和兩個數之間不能有空格。

?

當該字符緊跟在任何一個其餘限制符(*,+,?{n}{n,}{n,m})後面時,匹配模式是非貪婪的。非貪婪模式儘量少的匹配所搜索的字符串,而默認的貪婪模式則儘量多的匹配所搜索的字符串。例如,對於字符串「oooo」「o+?」將匹配單個「o」,而「o+」將匹配全部「o」

.

匹配除「\r\n」以外的任何單個字符。要匹配包括「\r\n」在內的任何字符,請使用像「[\s\S]」的模式。

(pattern)

匹配pattern並獲取這一匹配。所獲取的匹配能夠從產生的Matches集合獲得,在VBScript中使用SubMatches集合,在JScript中則使用$0…$9屬性。要匹配圓括號字符,請使用「\(」「\)」

(?:pattern)

匹配pattern但不獲取匹配結果,也就是說這是一個非獲取匹配,不進行存儲供之後使用。這在使用或字符「(|)」來組合一個模式的各個部分是頗有用。例如「industr(?:y|ies)」就是一個比「industry|industries」更簡略的表達式。

(?=pattern)

正向確定預查,在任何匹配pattern的字符串開始處匹配查找字符串。這是一個非獲取匹配,也就是說,該匹配不須要獲取供之後使用。例如,「Windows(?=95|98|NT|2000)」能匹配「Windows2000」中的「Windows」,但不能匹配「Windows3.1」中的「Windows」。預查不消耗字符,也就是說,在一個匹配發生後,在最後一次匹配以後當即開始下一次匹配的搜索,而不是從包含預查的字符以後開始。

(?!pattern)

正向否認預查,在任何不匹配pattern的字符串開始處匹配查找字符串。這是一個非獲取匹配,也就是說,該匹配不須要獲取供之後使用。例如「Windows(?!95|98|NT|2000)」能匹配「Windows3.1」中的「Windows」,但不能匹配「Windows2000」中的「Windows」

(?<=pattern)

反向確定預查,與正向確定預查相似,只是方向相反。例如,「(?<=95|98|NT|2000)Windows」能匹配「2000Windows」中的「Windows」,但不能匹配「3.1Windows」中的「Windows」

(?<!pattern)

反向否認預查,與正向否認預查相似,只是方向相反。例如「(?<!95|98|NT|2000)Windows」能匹配「3.1Windows」中的「Windows」,但不能匹配「2000Windows」中的「Windows」

x|y

匹配xy。例如,「z|food」能匹配「z」「food」"zood"(此處請謹慎)「(z|f)ood」則匹配「zood」「food」

[xyz]

字符集合。匹配所包含的任意一個字符。例如,「[abc]」能夠匹配「plain」中的「a」

[^xyz]

負值字符集合。匹配未包含的任意字符。例如,「[^abc]」能夠匹配「plain」中的「plin」

[a-z]

字符範圍。匹配指定範圍內的任意字符。例如,「[a-z]」能夠匹配「a」「z」範圍內的任意小寫字母字符。

注意:只有連字符在字符組內部時,而且出如今兩個字符之間時,才能表示字符的範圍若是出字符組的開頭,則只能表示連字符自己.

[^a-z]

負值字符範圍。匹配任何不在指定範圍內的任意字符。例如,「[^a-z]」能夠匹配任何不在「a」「z」範圍內的任意字符。

\b

匹配一個單詞邊界,也就是指單詞和空格間的位置(即正則表達式的匹配有兩種概念,一種是匹配字符,一種是匹配位置,這裏的\b就是匹配位置的)。例如,「er\b」能夠匹配「never」中的「er」,但不能匹配「verb」中的「er」

\B

匹配非單詞邊界。「er\B」能匹配「verb」中的「er」,但不能匹配「never」中的「er」

\cx

匹配由x指明的控制字符。例如,\cM匹配一個Control-M或回車符。x的值必須爲A-Za-z之一。不然,將c視爲一個原義的「c」字符。

\d

匹配一個數字字符。等價於[0-9]

\D

匹配一個非數字字符。等價於[^0-9]

\f

匹配一個換頁符。等價於\x0c\cL

\n

匹配一個換行符。等價於\x0a\cJ

\r

匹配一個回車符。等價於\x0d\cM

\s

匹配任何不可見字符,包括空格、製表符、換頁符等等。等價於[ \f\n\r\t\v]

\S

匹配任何可見字符。等價於[^ \f\n\r\t\v]

\t

匹配一個製表符。等價於\x09\cI

\v

匹配一個垂直製表符。等價於\x0b\cK

\w

匹配包括下劃線的任何單詞字符。相似但不等價於「[A-Za-z0-9_]」,這裏的"單詞"字符使用Unicode字符集。

\W

匹配任何非單詞字符。等價於「[^A-Za-z0-9_]」

\xn

匹配n,其中n爲十六進制轉義值。十六進制轉義值必須爲肯定的兩個數字長。例如,「\x41」匹配「A」「\x041」則等價於「\x04&1」。正則表達式中可使用ASCII編碼。

\num

匹配num,其中num是一個正整數。對所獲取的匹配的引用。例如,「(.)\1」匹配兩個連續的相同字符。

\n

標識一個八進制轉義值或一個向後引用。若是\n以前至少n個獲取的子表達式,則n爲向後引用。不然,若是n爲八進制數字(0-7),則n爲一個八進制轉義值。

\nm

標識一個八進制轉義值或一個向後引用。若是\nm以前至少有nm個得到子表達式,則nm爲向後引用。若是\nm以前至少有n個獲取,則n爲一個後跟文字m的向後引用。若是前面的條件都不知足,若nm均爲八進制數字(0-7),則\nm將匹配八進制轉義值nm

\nml

若是n爲八進制數字(0-7),且ml均爲八進制數字(0-7),則匹配八進制轉義值nml

\un

匹配n,其中n是一個用四個十六進制數字表示的Unicode字符。例如,\u00A9匹配版權符號(©)。

\< \>

匹配詞(word)的開始(\<)和結束(\>)。例如正則表達式\<the\>可以匹配字符串"for the wise"中的"the",可是不能匹配字符串"otherwise"中的"the"。注意:這個元字符不是全部的軟件都支持的。

\( \)

將 \( 和 \) 之間的表達式定義爲group),而且將匹配這個表達式的字符保存到一個臨時區域(一個正則表達式中最多能夠保存9個),它們能夠用 \1 \9 的符號來引用。

|

將兩個匹配條件進行邏輯Or)運算。例如正則表達式(him|her) 匹配"it belongs to him""it belongs to her",可是不能匹配"it belongs to them."。注意:這個元字符不是全部的軟件都支持的。

+

匹配1或多個正好在它以前的那個字符。例如正則表達式9+匹配999999等。注意:這個元字符不是全部的軟件都支持的。

?

匹配01個正好在它以前的那個字符。注意:這個元字符不是全部的軟件都支持的。

{i} {i,j}

匹配指定數目的字符,這些字符是在它以前的表達式定義的。例如正則表達式A[0-9]{3} 可以匹配字符"A"後面跟着正好3個數字字符的串,例如A123A348等,可是不匹配A1234。而正則表達式[0-9]{4,6} 匹配連續的任意4個、5個或者6個數字

 小夥伴們不要被上面的表格嚇壞了,下面我會以C#中應用正則表達式爲例一一說明的,上面的表格中的元字符在從此的應用中,能夠做爲查閱和參考。

3. C#中使用正則表達式

3.1 C#中正則表達式的命名空間

System.Text.RegularExpressions 命名空間包含一些類,這些類提供對 .NET Framework 正則表達式引擎的訪問。 該命名空間提供正則表達式功能,能夠從運行在 Microsoft .NET Framework 內的任何平臺或語言中使用該功能。 除了此命名空間中包含的類型外,System.Configuration.RegexStringValidator 類還容許您肯定特定字符串是否與某個正則表達式模式相符。

總結一下,在.net中有兩個命名空間用於操做正則表達式

A.System.Text.RegularExpressions 命名空間下在的類、委託、枚舉https://msdn.microsoft.com/zh-cn/library/system.text.regularexpressions.aspx

B.System.Configuration.RegexStringValidator 類

3.2 經常使用的操做正則表達式的方法和委託

其中System.Text.RegularExpressions 下的Regex類中提供了不少靜態方法(比較經常使用的有IsMatch、Match、Matches、Replace、Split等)和委託MatchEvaluator .

3.2.1 靜態方法IsMatch

IsMatch 方法返回值爲一個布爾型,主要用於判斷指定的字符串是否與正則表達式字符串匹配,它有三個重載方法

bool IsMatch(string input, string pattern);

參數: input:       要搜索匹配項的字符串。

      pattern:     要匹配的正則表達式模式。
 返回結果:  若是正則表達式找到匹配項,則爲 true;不然,爲 false。

bool IsMatch(string input, string pattern, RegexOptions options);

參數: input:       要搜索匹配項的字符串。

      pattern:     要匹配的正則表達式模式。
      options:     枚舉值的一個按位組合,這些枚舉值提供匹配選項。
返回結果:  若是正則表達式找到匹配項,則爲 true;不然,爲 false。

options下面有詳細說明

bool IsMatch(string input, string pattern, RegexOptions options, TimeSpan matchTimeout);

參數: input:        要搜索匹配項的字符串。

      pattern:      要匹配的正則表達式模式。
      options:      枚舉值的一個按位組合,這些枚舉值提供匹配選項。
      matchTimeout: 超時間隔,或 System.Text.RegularExpressions.Regex.InfiniteMatchTimeout 指示該方法不該超時。
返回結果:  若是正則表達式找到匹配項,則爲 true;不然,爲 false。

3.2.2 關於參數RegexOptions options

正則表達式選項RegexOptions有以下一下選項,詳細說明請參考聯機幫助

RegexOptions枚舉值

內聯標誌

簡單說明

ExplicitCapture

n

只有定義了命名或編號的組才捕獲

IgnoreCase

i

不區分大小寫

IgnorePatternWhitespace

x

消除模式中的非轉義空白並啓用由 # 標記的註釋。

MultiLine

m

多行模式,其原理是修改了^和$的含義

SingleLine

s

單行模式,和MultiLine相對應

這裏我提到內聯標誌,是由於相對於用RegexOptions在new Regex時定義Regex表達式的全局選項來講,內聯標誌能夠更小粒度(以組爲單位)的定義匹配選項,從而更方便表達咱們的思想

語法是這樣的:(?i:expression)爲定義一個選項,(?-i:expression)爲刪除一個選項,(?i-s:expression)則定義i,刪除s,是的,咱們能夠一次定義不少個選項。這樣,經過內聯選項,你就能夠在一個Regex中定義一個組爲匹分大小寫的,一個組不匹分大小寫的

3.2.3  靜態方法Match

靜態方法Match,使用指定的匹配選項在輸入字符串中搜索指定的正則表達式的第一個匹配項。 返回一個包含有關匹配的信息的對象。一樣有三個重載方法,參數和IsMatch方法相同。此外,在Regex類中,還有一個同名的非靜態方法,適用於多個實例的狀況下,效率更高一些。

Match Match(string input, string pattern);
Match Match(string input, string pattern, RegexOptions options);
Match Match(string input, string pattern, RegexOptions options, TimeSpan matchTimeout);

3.2.4  靜態方法Matches

靜態方法Matches,在指定的輸入字符串中搜索指定的正則表達式的全部匹配項。跟上面方法不一樣之處,就是這個方法返回的是全部匹配項,他一樣有三個重載方法,而且參數和Match方法徹底相同

Match Matches(string input, string pattern);
Match Matches(string input, string pattern, RegexOptions options);
Match Matches(string input, string pattern, RegexOptions options, TimeSpan matchTimeout);

3.2.5  Replace函數有四個重載函數

咱們知道正則表達式主要是實現驗證,提取,分割,替換字符的功能.Replace函數是實現替換功能的.

1 )Replace(string input,string pattern,string replacement)  

//input是源字符串,pattern是匹配的條件,replacement是替換的內容,就是把符合匹配條件pattern的內容轉換成它

好比string result = Regex.Replace("abc", "ab", "##");  

//結果是##c,就是把字符串abc中的ab替換成##

2 )Replace(string input,string pattern,string replacement,RegexOptions options)      

//RegexOptions是一個枚舉類型,用來作一些設定.

//前面用註釋時就用到了RegexOptions.IgnorePatternWhitespace.若是在匹配時忽略大小寫就能夠用RegexOptions.IgnoreCase

好比string result = Regex.Replace("ABc", "ab", "##",RegexOptions.IgnoreCase);

若是是簡單的替換用上面兩個函數就能夠實現了.但若是有些複雜的替換,好比匹配到不少內容,不一樣的內容要替換成不一樣的字符.就須要用到下面兩個函數

3 )Replace(string input,string pattern,MatchEvaluator evaluator);    

//evaluator是一個代理,其實簡單的說是一個函數指針,把一個函數作爲參數參進來

//因爲C#裏沒有指針就用代理來實現相似的功能.你能夠用代理綁定的函數來指定你要實現的複雜替換.

4 )Replace(string input,string pattern,MatchEvaluator evaluator,RegexOptions options);

//這個函數上上面的功能同樣,只不過多了一點枚舉類型來指定是否忽略大小寫等設置

3.2.6 靜態方法Split拆分文本

使用正則表達式匹配的位置,將文本拆分爲一個字符串數組,一樣有三個重載方法,返回值爲字符串數組

string[] Split(string input, string pattern);
string[] Match(string input, string pattern, RegexOptions options);
string[] Match(string input, string pattern, RegexOptions options, TimeSpan matchTimeout);

下面咱們會分別介紹最經常使用的正則表達式的使用

4. @符號

在「@」雖然並不是C#正則表達式的「成員」,可是它常常與C#正則表達式出雙入對。「@」表示,跟在它後面的字符串是個「逐字字符串」,

示例:

string strFirst="C:\\Program Files\\IIS";
string strSecond=@"C:\Program Files\IIS";
Console.WriteLine(strFirst);
Console.WriteLine(strSecond);

以上定義字符串是等價的。

5. 定位字符

字符

說明

\b

匹配單詞的開始或結束

\B

匹配非單詞的開始或結束

^

匹配必須出如今字符串的開頭或行的開頭

$

匹配必須出如今如下位置:字符串結尾、字符串結尾處的 \n 以前或行的結尾。

\A

指定匹配必須出如今字符串的開頭(忽略 Multiline 選項)。

\z

指定匹配必須出如今字符串的結尾(忽略 Multiline 選項)。

\z

指定匹配必須出如今字符串的結尾或字符串結尾處的 \n 以前(忽略 Multiline 選項)。

\G

指定匹配必須出如今上一個匹配結束的地方。與 Match.NextMatch() 一塊兒使用時,此斷言確保全部匹配都是連續的。

表 定位元字符

示例一:區配開始 ^

string str = "I am Blue cat";           
Console.WriteLine(Regex.Replace(str, "^","準備開始:"));

輸出結果爲:

 

示例二: 區始結束 $

string str = "I am Blue cat";           
Console.WriteLine(Regex.Replace(str, "$", "  結束了!"));

輸出結果爲:

 

6. 字符轉義 \

當咱們要查詢元字符時,好比查詢 * 或 . 必須使用轉義符 \,固然查詢/必須使用\\

7. 基本語法元字符

字符

說明

.

匹配除換行符之外的任意字符

\w

匹配字母、數字、下線下、漢字

(指大小寫字母、0-9的數字、下劃線_)

\W

\w的補集

( 除「大小寫字母、0-9的數字、下劃線_」以外

\s

匹配任意空白符

(包括換行符/n、回車符/r、製表符/t、垂直製表符/v、換頁符/f)

\S

\s的補集

(\s定義的字符以外)

\d

匹配數字

(0-9數字)

\D

表示\d的補集

(0-9數字以外)

7基本語法元字符

示例一:校驗只容許輸入數字

string strCheckNum1 = "23423423a3", strCheckNum2 = "324234";
Console.WriteLine("匹配字符串"+strCheckNum1+"是否爲數字:"+Regex.IsMatch(strCheckNum1, @"^\d*$"));
Console.WriteLine("匹配字符串" + strCheckNum2 + "是否爲數字:" + Regex.IsMatch(strCheckNum2, @"^\d*$"));

輸出結果爲:

 

其中*表示重複屢次檢查字符,後面重複字符中會具體說明

示例二:校驗只容許輸入除大小寫字母、0-9的數字、下劃線_之外的任何字

//示例二:校驗只容許輸入除大小寫字母、0-9的數字、下劃線_之外的任何字符
string strCheckStr1 = "abcds_a", strCheckStr2 = "**&&((((2", strCheckStr3 = "**&&((((";
string regexStr = @"^\W*$";
Console.WriteLine("匹配字符串" + strCheckStr1 + "是否爲除大小寫字母、0-9的數字、下劃線_之外的任何字符:" + Regex.IsMatch(strCheckStr1, regexStr));
Console.WriteLine("匹配字符串" + strCheckStr2 + "是否爲除大小寫字母、0-9的數字、下劃線_之外的任何字符:" + Regex.IsMatch(strCheckStr2, regexStr));
Console.WriteLine("匹配字符串" + strCheckStr3 + "是否爲除大小寫字母、0-9的數字、下劃線_之外的任何字符:" + Regex.IsMatch(strCheckStr3, regexStr));

輸出結果爲:

 

8. 反義

字符

說明

\W

\w的補集

( 除「大小寫字母、0-9的數字、下劃線_」以外)

\S

\s的補集

(\s定義的字符以外)

\D

表示\d的補集

(0-9數字以外)

\B

匹配不是單詞開頭或結束的位置

[^x]

匹配除了x之外的任意字符

[^adwz]

匹配除了adwz這幾個字符之外的任意字符

表8 反義字符

上面的示例中已經使用到到反義了,咱們舉一個匹配除某些字母外的任意字符

示例:查找除ahou這以外的全部字符

//示例:查找除ahou這以外的全部字符
string strFind1 = "I am a Cat!", strFind2 = "My Name's Blue cat!";             
Console.WriteLine("除ahou這以外的全部字符,原字符爲:" + strFind1 + "替換後:" + Regex.Replace(strFind1, @"[^ahou]","*")); Console.WriteLine("除ahou這以外的全部字符,原字符爲:" + strFind2 + "替換後:" + Regex.Replace(strFind2, @"[^ahou]", "*"));

執行結果爲:

 

9. 重複描述字符

字符

說明

{n} 

匹配前面的字符n

{n,}

匹配前面的字符n次或多於n

{n,m}

匹配前面的字符nm

?

重複零次或一次

+

重複一次或更屢次

*

重複零次或更屢次

重複描述字符

前面已經學習了 表示重複檢索多個字符,下面咱們具體應用一個實例

示例:校驗輸入內容是否爲合法QQ(備註:QQ號爲5-12位數字)

//示例:校驗輸入內容是否爲合法QQ號(備註:QQ號爲5 - 12位數字)
string isQq1 = "1233", isQq2 = "a1233", isQq3 = "0123456789123", isQq4 = "556878544";
string regexQq = @"^\d{5,12}$";
Console.WriteLine(isQq1+"是否爲合法QQ號(5-12位數字):" + Regex.IsMatch(isQq1, regexQq));
Console.WriteLine(isQq2 + "是否爲合法QQ號(5-12位數字):" + Regex.IsMatch(isQq2, regexQq));
Console.WriteLine(isQq3 + "是否爲合法QQ號(5-12位數字):" + Regex.IsMatch(isQq3, regexQq));
Console.WriteLine(isQq4 + "是否爲合法QQ號(5-12位數字):" + Regex.IsMatch(isQq4, regexQq));

運行結果爲:

 

10. 擇一匹配

字符

說明

|

將兩個匹配條件進行邏輯Or)運算。

 示例一:查找數字或字母

//示例:查找數字或字母
string findStr1 = "ad(d3)-df";
string regexFindStr = @"[a-z]|\d";
string newStrFind=String.Empty;
MatchCollection newStr =  Regex.Matches(findStr1, regexFindStr);
 newStr.Cast<Match>().Select(m => m.Value).ToList<string>().ForEach(i => newStrFind += i);
Console.WriteLine(findStr1 + "中的字母和數字組成的新字符串爲:" + newStrFind);

輸出結果爲:

 

示例二:將人名輸出("zhangsan;lisi,wangwu.zhaoliu")

//示例:使用Split方法拆分
string strSplit = "zhangsan;lisi,wangwu.zhaoliu";
string regexSplitstr = @"[;]|[,]|[.]";
Regex.Split(strSplit, regexSplitstr).ToList().ForEach(i => Console.WriteLine(i));

輸出結果以下:

示例三:校驗國內電話號碼(支持三種寫法校驗 A. 010-87654321 B. (010)87654321 C.01087654321 D.010 87654321)

//示例:校驗國內電話號碼(支持三種寫法校驗 A. 010-87654321  B. (010)87654321  C.01087654321  D.010 87654321)
string TelNumber1 = "(010)87654321", TelNumber2 = "010-87654321", TelNumber3 = "01087654321",
        TelNumber4 = "09127654321", TelNumber5 = "010)87654321",TelNumber6="(010-87654321",
        TelNumber7="91287654321";
Regex  RegexTelNumber1 =new Regex(@"\(?0\d{2,3}[-)]?\d{7,8}");
Console.WriteLine( "電話號碼 "+TelNumber1+" 是否合法:" + RegexTelNumber1.IsMatch(TelNumber1));
Console.WriteLine("電話號碼 " + TelNumber2 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber2));
Console.WriteLine("電話號碼 " + TelNumber3 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber3));
Console.WriteLine("電話號碼 " + TelNumber4 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber4));
Console.WriteLine("電話號碼 " + TelNumber5 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber5));
Console.WriteLine("電話號碼 " + TelNumber6 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber6));
Console.WriteLine("電話號碼 " + TelNumber7 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber7));

Console.WriteLine("\n");

//上面未使用擇一寫法,致使TelNumber4和TelNumber5被合法化
//注意第二個分枝加了^ $符,表示從頭至尾檢索,不加的開始符,容易產生(010-87654321合法化(網上30分鐘正則教程中,就存在此錯誤)
//改進使用擇一寫法後以下:

Console.WriteLine("\n");

Regex RegexTelNumber3 = new Regex(@"\(0\d{2,3}\)[- ]?\d{7,8}|^0\d{2,3}[- ]?\d{7,8}$");
       
Console.WriteLine("電話號碼 " + TelNumber1 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber1));
Console.WriteLine("電話號碼 " + TelNumber2 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber2));
Console.WriteLine("電話號碼 " + TelNumber3 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber3));
Console.WriteLine("電話號碼 " + TelNumber4 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber4));
Console.WriteLine("電話號碼 " + TelNumber5 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber5));
Console.WriteLine("電話號碼 " + TelNumber6 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber6));
Console.WriteLine("電話號碼 " + TelNumber7 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber7));

運行結果以下:

 11. 要點:

A.本篇主要說明了正則表達式的基本元字符及使用方法舉例

B.說明了C#中使用正則表達式的幾種方法 

這些只是最基礎的正則表達式的內容,學習本節內容,咱們還不能完成複雜的正則表達式,

在下一節中,咱們會繼續說明正則表達式更深層次的使用。

下面附本節全部示例代碼: 

 1 //開始和結束符 ^  $
 2 string str = "I am Blue cat";           
 3 Console.WriteLine(Regex.Replace(str, "^","準備開始:"));
 4 string str2 = "I am Blue cat";
 5 Console.WriteLine(Regex.Replace(str2, "$", "  結束了!"));
 6 
 7 string str3 = "myWord.*";
 8 Console.WriteLine(Regex.Replace(str3, ".*", ".doc"));
 9 
10 //示例:校驗只容許輸入數字
11 
12 string strCheckNum1 = "23423423a3", strCheckNum2 = "324234";
13 Console.WriteLine("匹配字符串"+strCheckNum1+"是否爲數字:"+Regex.IsMatch(strCheckNum1, @"^\d*$"));
14 Console.WriteLine("匹配字符串" + strCheckNum2 + "是否爲數字:" + Regex.IsMatch(strCheckNum2, @"^\d*$"));
15 
16 //示例二:校驗只容許輸入除大小寫字母、0-9的數字、下劃線_之外的任何字符
17 string strCheckStr1 = "abcds_a", strCheckStr2 = "**&&((((2", strCheckStr3 = "**&&((((";
18 string regexStr = @"^\W*$";
19 Console.WriteLine("匹配字符串" + strCheckStr1 + "是否爲除大小寫字母、0-9的數字、下劃線_之外的任何字符:" + Regex.IsMatch(strCheckStr1, regexStr));
20 Console.WriteLine("匹配字符串" + strCheckStr2 + "是否爲除大小寫字母、0-9的數字、下劃線_之外的任何字符:" + Regex.IsMatch(strCheckStr2, regexStr));
21 Console.WriteLine("匹配字符串" + strCheckStr3 + "是否爲除大小寫字母、0-9的數字、下劃線_之外的任何字符:" + Regex.IsMatch(strCheckStr3, regexStr));
23 
24 //示例:查找除ahou這以外的全部字符
25 string strFind1 = "I am a Cat!", strFind2 = "My Name's Blue cat!";            
26 Console.WriteLine("除ahou這以外的全部字符,原字符爲:" + strFind1 + "替換後:" + Regex.Replace(strFind1, @"[^ahou]","*"));
27 Console.WriteLine("除ahou這以外的全部字符,原字符爲:" + strFind2 + "替換後:" + Regex.Replace(strFind2, @"[^ahou]", "*"));
28 
29 //示例:校驗輸入內容是否爲合法QQ號(備註:QQ號爲5 - 12位數字)
30 string isQq1 = "1233", isQq2 = "a1233", isQq3 = "0123456789123", isQq4 = "556878544";
31 string regexQq = @"^\d{5,12}$";
32 Console.WriteLine(isQq1+"是否爲合法QQ號(5-12位數字):" + Regex.IsMatch(isQq1, regexQq));
33 Console.WriteLine(isQq2 + "是否爲合法QQ號(5-12位數字):" + Regex.IsMatch(isQq2, regexQq));
34 Console.WriteLine(isQq3 + "是否爲合法QQ號(5-12位數字):" + Regex.IsMatch(isQq3, regexQq));
35 Console.WriteLine(isQq4 + "是否爲合法QQ號(5-12位數字):" + Regex.IsMatch(isQq4, regexQq));
37 
38 //示例:查找數字或字母
39 string findStr1 = "ad(d3)-df";
40 string regexFindStr = @"[a-z]|\d";
41 string newStrFind=String.Empty;
42 MatchCollection newStr =  Regex.Matches(findStr1, regexFindStr);
43 newStr.Cast<Match>().Select(m => m.Value).ToList<string>().ForEach(i => newStrFind += i);
44 Console.WriteLine(findStr1 + "中的字母和數字組成的新字符串爲:" + newStrFind);
45 
46 //示例:使用Split方法拆分
47 string strSplit = "zhangsan;lisi,wangwu.zhaoliu";
48 string regexSplitstr = @"[;]|[,]|[.]";
49 Regex.Split(strSplit, regexSplitstr).ToList().ForEach(i => Console.WriteLine(i));
52 
53 //示例:校驗國內電話號碼(支持三種寫法校驗 A. 010-87654321  B. (010)87654321  C.01087654321  D.010 87654321)
54 string TelNumber1 = "(010)87654321", TelNumber2 = "010-87654321", TelNumber3 = "01087654321",
55         TelNumber4 = "09127654321", TelNumber5 = "010)87654321",TelNumber6="(010-87654321",
56         TelNumber7="91287654321";
57 Regex  RegexTelNumber1 =new Regex(@"\(?0\d{2,3}[-)]?\d{7,8}");
58 Console.WriteLine( "電話號碼 "+TelNumber1+" 是否合法:" + RegexTelNumber1.IsMatch(TelNumber1));
59 Console.WriteLine("電話號碼 " + TelNumber2 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber2));
60 Console.WriteLine("電話號碼 " + TelNumber3 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber3));
61 Console.WriteLine("電話號碼 " + TelNumber4 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber4));
62 Console.WriteLine("電話號碼 " + TelNumber5 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber5));
63 Console.WriteLine("電話號碼 " + TelNumber6 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber6));
64 Console.WriteLine("電話號碼 " + TelNumber7 + " 是否合法:" + RegexTelNumber1.IsMatch(TelNumber7));
65 
66 Console.WriteLine("\n");
67 
68 //上面未使用擇一寫法,致使TelNumber4和TelNumber5被合法化
69 //注意第二個分枝加了^ $符,表示從頭至尾檢索,不加的開始符,容易產生(010-87654321合法化(網上30分鐘正則教程中,就存在此錯誤)
70 //改進使用擇一寫法後以下:
71 
72 Console.WriteLine("\n");
73 
74 Regex RegexTelNumber3 = new Regex(@"\(0\d{2,3}\)[- ]?\d{7,8}|^0\d{2,3}[- ]?\d{7,8}$");
75        
76 Console.WriteLine("電話號碼 " + TelNumber1 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber1));
77 Console.WriteLine("電話號碼 " + TelNumber2 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber2));
78 Console.WriteLine("電話號碼 " + TelNumber3 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber3));
79 Console.WriteLine("電話號碼 " + TelNumber4 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber4));
80 Console.WriteLine("電話號碼 " + TelNumber5 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber5));
81 Console.WriteLine("電話號碼 " + TelNumber6 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber6));
82 Console.WriteLine("電話號碼 " + TelNumber7 + " 是否合法:" + RegexTelNumber3.IsMatch(TelNumber7));

==============================================================================================  

 返回目錄

 <若是對你有幫助,記得點一下推薦哦,若有

有不明白或錯誤之處,請多交流>  

<對本系列文章閱讀有困難的朋友,請先看《.net 面向對象編程基礎》>

<轉載聲明:技術須要共享精神,歡迎轉載本博客中的文章,但請註明版權及URL>

.NET 技術交流羣:467189533    .NET 程序設計

==============================================================================================   

相關文章
相關標籤/搜索