iOS中正則表達(dá)式的基本使用方法

聲明:本文基本是轉(zhuǎn)載千葉的博客,里面稍微修改。

一、通過(guò)第三方類庫(kù)正則匹配

在ios項(xiàng)目中可以借用第三方框架RegexKitLite來(lái)簡(jiǎn)化對(duì)正則表達(dá)式的使用,使用方法如下:

1)、通過(guò)cocoapods同步類庫(kù)

2)、工程中添加libicucore.dylib frameworks。

下面就是使用介紹(可拷貝到Xcode中觀看會(huì)很方便)

- (void)howToUseRegexKitLite

{

NSString *searchString = @"我正在#話題#吃飯@zhangsan 你@lisi 吃了沒(méi)?";

NSString *regexString = @"@\\w+";

// 返回所有匹配成功的結(jié)果,并存放到一個(gè)數(shù)組里

NSArray *array = [searchString componentsMatchedByRegex:regexString];

NSLog(@"array:%@",array); // 輸出結(jié)果: ("@zhangsan","@lisi")

// 透過(guò)傳入一個(gè)Regex進(jìn)行字符串的比對(duì),并且會(huì)將第一組比對(duì)出來(lái)的結(jié)果以NSArray回傳群組

NSArray *array1 = [searchString captureComponentsMatchedByRegex:regexString];

NSLog(@"array1:%@",array1); // 輸出結(jié)果: ("@zhangsan")

// 同上者,一樣會(huì)回傳Regex所比對(duì)出來(lái)的字符串群組,但會(huì)回傳全部的配對(duì)組合

NSArray *array2 = [searchString arrayOfCaptureComponentsMatchedByRegex:regexString];

NSLog(@"array2:%@",array2); // 輸出結(jié)果: (("@zhangsan"),("@lisi"))

// 判斷字符串是否與Regex配對(duì)

BOOL isMatched = [@"@zhangsan" isMatchedByRegex:regexString];

if (isMatched) {

NSLog(@"配對(duì)成功");

}

// 取得配對(duì)出來(lái)的第一個(gè)完整字串

NSString *matchedString1 = [searchString stringByMatching:regexString];

NSLog(@"matchedString1:%@",matchedString1); // 輸出結(jié)果: @zhangsan

// 將字符串中與Regex配對(duì)的結(jié)果進(jìn)行替換

NSString *replaceString = @"wangwu";

NSString *matchedString2 = [searchString stringByReplacingOccurrencesOfRegex:regexString withString:replaceString];

NSLog(@"matchedString2:%@",matchedString2); // 輸出結(jié)果: 我正在#話題#吃飯wangwu 你wangwu 吃了沒(méi)?

// 如果是NSMutableString,則可以直接替換,并返回替換的次數(shù)

NSMutableString *mutSearchString = [NSMutableString stringWithString:@"我正在#話題#吃放@zhangsan 你@lisi 吃了沒(méi)?"];

NSInteger mutMatchedString2 = [mutSearchString replaceOccurrencesOfRegex:regexString withString:replaceString];

NSLog(@"mutMatchedString2:%ld",mutMatchedString2); // 輸出結(jié)果: 2

// 返回一個(gè)拆分后的字符串?dāng)?shù)組

NSArray *array3 = [searchString componentsSeparatedByRegex:regexString];

NSLog(@"array3:%@",array3); // 輸出結(jié)果: ("我正在#話題#吃飯"," 你"," 吃了沒(méi)?")

}

#pragma mark RegexKitLite的使用總結(jié)

/*

RegexKitLite提供的方法都是透過(guò)NSString來(lái)操作,常用的方法:

1. - (NSArray *)RKL_METHOD_PREPEND(componentsMatchedByRegex):(NSString *)regex

返回所有匹配成功的結(jié)果,并存放到一個(gè)數(shù)組里

2. - (NSArray *)captureComponentsMatchedByRegex:(NSString *)regex;

這個(gè)方法是透過(guò)傳入一個(gè)Regex進(jìn)行字串的比對(duì),并且會(huì)將第一組比對(duì)出來(lái)的結(jié)果以NSArray回傳群組。

3. - (NSArray *)arrayOfCaptureComponentsMatchedByRegex:(NSString *)regex;

這個(gè)方法如同上者,一樣會(huì)回傳Regex所比對(duì)出來(lái)的字串群組,但會(huì)回傳全部的配對(duì)組合。

4. - (BOOL)isMatchedByRegex:(NSString *)regex;

判斷字串是否與Regex配對(duì),在進(jìn)行資料驗(yàn)證的時(shí)候很實(shí)用。

5. - (NSString *)stringByMatching:(NSString *)regex;

這方法則是會(huì)回傳配對(duì)出來(lái)的第一個(gè)完整字串。

6. - (NSString *)stringByReplacingOccurrencesOfRegex:(NSString *)regex withString:(NSString *)replacement;

將字串中與Regex配對(duì)的結(jié)果進(jìn)行替換。

7. - (NSInteger)replaceOccurrencesOfRegex:(NSString *)regex withString:(NSString *)replacement

如果是NSMutableString,則可以直接替換,并返回替換的次數(shù)

8. - (NSArray *)componentsSeparatedByRegex:(NSString *)regex

用于拆分,返回一個(gè)拆分后的字符串?dāng)?shù)組

*/

二、正則表達(dá)式的使用

- (void)howToUseRegex

{

#pragma mark 1.正則表達(dá)式規(guī)則

/*-------------------------------1.1普通字符-------------------------------*/

// 字母、數(shù)字、漢字、下劃線、非特殊定義的標(biāo)點(diǎn)符號(hào),都是"普通字符"。表達(dá)式中的普通字符,在匹配一個(gè)字符串的時(shí)候,匹配與之相同的一個(gè)字符。

NSString *searchString1_1 = @"abcde";

NSString *regexString1_1 = @"c";

NSString *matchedString1_1 = [searchString1_1 stringByMatching:regexString1_1];

NSLog(@"matchedString1_1:%@",matchedString1_1); // 輸出結(jié)果: c

/*-------------------------------1.2簡(jiǎn)單的轉(zhuǎn)義字符-------------------------------*/

// 一些不便書寫的字符,在前面加 "\",如:\n,\t,\\ 等

NSString *searchString1_2 = @"abc$de";

// 記住在字符串中“\”需要用“\\”表示

NSString *regexString1_2 = @"\\$d";

NSString *matchedString1_2 = [searchString1_2 stringByMatching:regexString1_2];

NSLog(@"matchedString1_2:%@",matchedString1_2); // 輸出結(jié)果: $d

/*------------------------1.3能夠與 '多種字符' 匹配的表達(dá)式-------------------------*/

/*

.? ? : 匹配除換行符以外的任意字符

\w? ? : 匹配字母或數(shù)字或下劃線或漢字

\s? ? : 匹配任意的空白符

\d? ? : 匹配數(shù)字

\b? ? : 匹配單詞的開始或結(jié)束

*/

NSString *searchString1_3 = @"abc123";

// 正則表達(dá)式有一條規(guī)則:最先開始的匹配擁有最高的優(yōu)先權(quán)

NSString *regexString1_3 = @"\\d\\d";

NSString *matchedString1_3 = [searchString1_3 stringByMatching:regexString1_3];

NSLog(@"matchedString1_3:%@",matchedString1_3); // 輸出結(jié)果: 12

/*---------------------1.4自定義能夠匹配 '多種字符' 的表達(dá)式-------------------------*/

// 使用方括號(hào) [ ] 包含一系列字符,能夠匹配其中任意一個(gè)字符。用 [^ ] 包含一系列字符,則能夠匹配其中字符之外的任意一個(gè)字符。同樣的道理,雖然可以匹配其中任意一個(gè),但是只能是一個(gè),不是多個(gè)。[]本身就隱含了“或”的關(guān)系,在[]中使用“|”表示“或”的關(guān)系是不對(duì)的,這樣做只是多了一個(gè)普通字符“|”,用來(lái)匹配“|”字符本身,()也是同樣道理。 如:

/*

[ab5@]? ? : 匹配 "a" 或 "b" 或 "5" 或 "@"

[^abc]? ? : 匹配 "a","b","c" 之外的任意一個(gè)字符

[f-k]? ? : 匹配 "f"~"k" 之間的任意一個(gè)字母

[^A-F0-3] : 匹配 "A"~"F","0"~"3" 之外的任意一個(gè)字符

*/

NSString *searchString1_4 = @"abc123";

NSString *regexString1_4 = @"[bcd][bcd]";

NSString *matchedString1_4 = [searchString1_4 stringByMatching:regexString1_4];

NSLog(@"matchedString1_4:%@",matchedString1_4); // 輸出結(jié)果: bc

/*---------------------1.5修飾匹配次數(shù)的特殊符號(hào)------------------------------*/

// 使用表達(dá)式再加上修飾匹配次數(shù)的特殊符號(hào),那么不用重復(fù)書寫表達(dá)式就可以重復(fù)匹配

/*

{n}? :? 表達(dá)式重復(fù)n次

{m,n} :? 表達(dá)式至少重復(fù)m次,最多重復(fù)n次

{m,}? :? 表達(dá)式至少重復(fù)m次

?? ? :? 匹配表達(dá)式0次或者1次,相當(dāng)于 {0,1}

+? ? :? 表達(dá)式至少出現(xiàn)1次,相當(dāng)于 {1,}

*? ? :? 表達(dá)式不出現(xiàn)或出現(xiàn)任意次,相當(dāng)于 {0,}

*/

NSString *searchString1_5 = @"It costs $12.5";

NSString *regexString1_5 = @"\\d+\\.?\\d";

NSString *matchedString1_5 = [searchString1_5 stringByMatching:regexString1_5];

NSLog(@"matchedString1_5:%@",matchedString1_5); // 輸出結(jié)果: 12.5

/*---------------------1.6其他一些代表抽象意義的特殊符號(hào)--------------------------*/

// 一些符號(hào)在表達(dá)式中代表抽象的特殊意義

/*

^? ? : 與字符串開始的地方匹配,不匹配任何字符

$? ? : 與字符串結(jié)束的地方匹配,不匹配任何字符

\b? ? : 匹配一個(gè)單詞邊界,也就是單詞和空格之間的位置,不匹配任何字符

*/

// 進(jìn)一步說(shuō)明:"\b" 與 "^" 和 "$" 類似,本身不匹配任何字符,但是它要求它在匹配結(jié)果中所處位置的左右兩邊,其中一邊是 "\w" 范圍,另一邊是 非"\w" 的范圍

NSString *searchString1_6 = @"@@@abc";

NSString *regexString1_6 = @".\\b.";

NSString *matchedString1_6 = [searchString1_6 stringByMatching:regexString1_6];

NSLog(@"matchedString1_6:%@",matchedString1_6); // 輸出結(jié)果: @a


#pragma mark 2.正則表達(dá)式中的一些高級(jí)規(guī)則

/*---------------------2.1匹配次數(shù)中的貪婪與非貪婪--------------------------*/

// 1)在使用修飾匹配次數(shù)的特殊符號(hào)"{m,n}", "{m,}", "?", "*", "+"可以使同一個(gè)表達(dá)式能夠匹配不同的次數(shù),這種重復(fù)匹配不定次數(shù)的表達(dá)式在匹配過(guò)程中,總是盡可能多的匹配。如:

NSString *searchString2_1_1 = @"dxxxdxxxd";

NSString *regexString2_1_1 = @"(d)(\\w+)(d)";

NSString *matchedString2_1_1 = [searchString2_1_1 stringByMatching:regexString2_1_1];

NSLog(@"matchedString2_1_1:%@",matchedString2_1_1); // 輸出結(jié)果: dxxxdxxxd

// 2)在修飾匹配次數(shù)的特殊符號(hào)后再加上一個(gè) "?" 號(hào),則可以使匹配次數(shù)不定的表達(dá)式盡可能少的匹配,這種匹配原則叫作 "非貪婪" 模式,也叫作 "勉強(qiáng)" 模式

NSString *regexString2_1_2 = @"(d)(\\w+?)(d)";

NSString *matchedString2_1_2 = [searchString2_1_1 stringByMatching:regexString2_1_2];

NSLog(@"matchedString2_1_2:%@",matchedString2_1_2); // 輸出結(jié)果: dxxxd

/*---------------------2.2反向引用--------------------------------------*/

// 使用小括號(hào)指定一個(gè)子表達(dá)式后,匹配這個(gè)子表達(dá)式的文本(也就是此分組捕獲的內(nèi)容)可以在表達(dá)式或其它程序中作進(jìn)一步的處理。默認(rèn)情況下,每個(gè)分組會(huì)自動(dòng)擁有一個(gè)組號(hào),規(guī)則是:從左向右,以分組的左括號(hào)為標(biāo)志,第一個(gè)出現(xiàn)的分組的組號(hào)為1,第二個(gè)為2,以此類推

NSString *searchString2_2 = @"go go";

NSString *regexString2_2 = @"\\b(\\w+)\\b\\s+\\1\\b";

NSString *matchedString2_2 = [searchString2_2 stringByMatching:regexString2_2];

NSLog(@"matchedString2_2:%@",matchedString2_2); // 輸出結(jié)果: go go

/*----------------2.3零寬斷言-------------------------------------------*/? ??

// 零寬斷言用于查找在某些內(nèi)容(但并不包括這些內(nèi)容)之前或之后的東西,也就是說(shuō)它們像\b,^,$那樣用于指定一個(gè)位置,這個(gè)位置應(yīng)該滿足一定的條件(即斷言),因此它們也被稱為零寬斷言? ? /*? ? ? ? ??

1)捕獲? ? ??

? (exp)? ? ? ? : 匹配exp,并捕獲文本到自動(dòng)命名的組里? ? ??

? (?exp)? : 匹配exp,并捕獲文本到名稱為name的組里,也可以寫成(?'name'exp)

? (?:exp)? ? ? : 匹配exp,不捕獲匹配的文本,也不給此分組分配組號(hào)零寬斷言,可節(jié)約性能,提高效率

2)零寬斷言

(?=exp)? ? ? : 匹配exp前面的位置

(?<=exp)? ? ? : 匹配exp后面的位置

(?!exp)? ? ? : 匹配后面跟的不是exp的位置

(?<!exp)? ? ? : 匹配前面不是exp的位置注釋(?#comment)這種類型的分組不對(duì)正則表達(dá)式的處理產(chǎn)生任何影響,用于提供注釋讓人閱讀

*/

NSString *searchString2_3 = @"I'm singing while you're dancing.";

NSString *regexString2_3 = @"\\b\\w+(?=ing\\b)";

NSArray *matchedString2_3 = [searchString2_3 componentsMatchedByRegex:regexString2_3];

NSLog(@"matchedString2_3:%@",matchedString2_3); // 輸出結(jié)果: (sing,danc)

// 3.其他通用規(guī)則

/*----------------3.1------------------------------------------*/

// 表達(dá)式中,可以使用 "\xXX" 和 "\uXXXX" 表示一個(gè)字符("X" 表示一個(gè)十六進(jìn)制數(shù))

/*

\xXX? ? : 編號(hào)在 0 ~ 255 范圍的字符,比如:空格可以使用 "\x20" 表示

\uXXXX? : 任何字符可以使用 "\u" 再加上其編號(hào)的4位十六進(jìn)制數(shù)表示,比如:"\u4E2D"

*/

/*----------------3.2------------------------------------------*/

// 在表達(dá)式 "\s","\d","\w","\b" 表示特殊意義的同時(shí),對(duì)應(yīng)的大寫字母表示相反的意義

/*

\S? ? : 匹配所有非空白字符("\s" 可匹配各個(gè)空白字符)

\D? ? : 匹配所有的非數(shù)字字符

\W? ? : 匹配所有的字母、數(shù)字、下劃線以外的字符

\B? ? : 匹配非單詞邊界,即左右兩邊都是 "\w" 范圍或者左右兩邊都不是 "\w" 范圍時(shí)的字符縫隙

*/

/*----------------3.3------------------------------------------*/

// 在表達(dá)式中有特殊意義,需要添加 "\" 才能匹配該字符本身的字符匯總

/*

^? ? : 匹配輸入字符串的開始位置。要匹配 "^" 字符本身,請(qǐng)使用 "\^"

$? ? : 匹配輸入字符串的結(jié)尾位置。要匹配 "$" 字符本身,請(qǐng)使用 "\$"

( )? : 標(biāo)記一個(gè)子表達(dá)式的開始和結(jié)束位置。要匹配小括號(hào),請(qǐng)使用 "\(" 和 "\)"

[ ]? : 用來(lái)自定義能夠匹配 '多種字符' 的表達(dá)式。要匹配中括號(hào),請(qǐng)使用 "\[" 和 "\]"

{ }? : 修飾匹配次數(shù)的符號(hào)。要匹配大括號(hào),請(qǐng)使用 "\{" 和 "\}"

.? ? : 匹配除了換行符(\n)以外的任意一個(gè)字符。要匹配小數(shù)點(diǎn)本身,請(qǐng)使用 "\."

?? ? : 修飾匹配次數(shù)為 0 次或 1 次。要匹配 "?" 字符本身,請(qǐng)使用 "\?"

+? ? : 修飾匹配次數(shù)為至少 1 次。要匹配 "+" 字符本身,請(qǐng)使用 "\+"

*? ? : 修飾匹配次數(shù)為 0 次或任意次。要匹配 "*" 字符本身,請(qǐng)使用 "\*"

|? ? : 左右兩邊表達(dá)式之間 "或" 關(guān)系。匹配 "|" 本身,請(qǐng)使用 "\|"

"? ? : 用在不帶@的字符串中時(shí),用\"來(lái)進(jìn)行轉(zhuǎn)義,用在帶@的字符串中時(shí),用""來(lái)進(jìn)行轉(zhuǎn)義

注意:大部分在正則中有特殊意義、在匹配其本身時(shí)需轉(zhuǎn)義的字符,在[]內(nèi)是不需要轉(zhuǎn)義的。必須轉(zhuǎn)義的只有“\”、“[”和“]”,而“^”出現(xiàn)在[]開始位置,“-”前后構(gòu)成范圍區(qū)間時(shí),需要轉(zhuǎn)義,出現(xiàn)在其它位置不需要轉(zhuǎn)義,如:[\^ .$^{\[(|)*+?\\-]

*/

}

附錄 一 : 常用正則表達(dá)式

一、校驗(yàn)數(shù)字的表達(dá)式

1 數(shù)字:^[0-9]*$

2 n位的數(shù)字:^\d{n}$

3 至少n位的數(shù)字:^\d{n,}$

4 m-n位的數(shù)字:^\d{m,n}$

5 零和非零開頭的數(shù)字:^(0|[1-9][0-9]*)$

6 非零開頭的最多帶兩位小數(shù)的數(shù)字:^([1-9][0-9]*)+(.[0-9]{1,2})?$

7 帶1-2位小數(shù)的正數(shù)或負(fù)數(shù):^(\-)?\d+(\.\d{1,2})?$

8 正數(shù)、負(fù)數(shù)、和小數(shù):^(\-|\+)?\d+(\.\d+)?$

9 有兩位小數(shù)的正實(shí)數(shù):^[0-9]+(.[0-9]{2})?$

10 有1~3位小數(shù)的正實(shí)數(shù):^[0-9]+(.[0-9]{1,3})?$

11 非零的正整數(shù):^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$

12 非零的負(fù)整數(shù):^\-[1-9][]0-9"*$ 或 ^-[1-9]\d*$

13 非負(fù)整數(shù):^\d+$ 或 ^[1-9]\d*|0$

14 非正整數(shù):^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$

15 非負(fù)浮點(diǎn)數(shù):^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$

16 非正浮點(diǎn)數(shù):^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$

17 正浮點(diǎn)數(shù):^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$

18 負(fù)浮點(diǎn)數(shù):^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$

19 浮點(diǎn)數(shù):^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$

二、校驗(yàn)字符的表達(dá)式

1 漢字:^[\u4e00-\u9fa5]{0,}$

2 英文和數(shù)字:^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$

3 長(zhǎng)度為3-20的所有字符:^.{3,20}$

4 由26個(gè)英文字母組成的字符串:^[A-Za-z]+$

5 由26個(gè)大寫英文字母組成的字符串:^[A-Z]+$

6 由26個(gè)小寫英文字母組成的字符串:^[a-z]+$

7 由數(shù)字和26個(gè)英文字母組成的字符串:^[A-Za-z0-9]+$

8 由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串:^\w+$ 或 ^\w{3,20}$

9 中文、英文、數(shù)字包括下劃線:^[\u4E00-\u9FA5A-Za-z0-9_]+$

10 中文、英文、數(shù)字但不包括下劃線等符號(hào):^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$

11 可以輸入含有^%&',;=?$\"等字符:[^%&',;=?$\x22]+

12 禁止輸入含有~的字符:[^~\x22]+

三、特殊需求表達(dá)式

1 Email地址:^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$

2 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?

3 InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$

4 手機(jī)號(hào)碼:^(13[0-9]|14[5|7]|15[0|1|2|3|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$

5 電話號(hào)碼("XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX):^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$

6 國(guó)內(nèi)電話號(hào)碼(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}

7 身份證號(hào)(15位、18位數(shù)字):^\d{15}|\d{18}$

8 短身份證號(hào)碼(數(shù)字、字母x結(jié)尾):^([0-9]){7,18}(x|X)?$ 或 ^\d{8,18}|[0-9x]{8,18}|[0-9X]{8,18}?$

9 帳號(hào)是否合法(字母開頭,允許5-16字節(jié),允許字母數(shù)字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$

10 密碼(以字母開頭,長(zhǎng)度在6~18之間,只能包含字母、數(shù)字和下劃線):^[a-zA-Z]\w{5,17}$

11 強(qiáng)密碼(必須包含大小寫字母和數(shù)字的組合,不能使用特殊字符,長(zhǎng)度在8-10之間):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$

12 日期格式:^\d{4}-\d{1,2}-\d{1,2}

13 一年的12個(gè)月(01~09和1~12):^(0?[1-9]|1[0-2])$

14 一個(gè)月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$

15 錢的輸入格式:

16? ? 1.有四種錢的表示形式我們可以接受:"10000.00" 和 "10,000.00", 和沒(méi)有 "分" 的 "10000" 和 "10,000":^[1-9][0-9]*$

17? ? 2.這表示任意一個(gè)不以0開頭的數(shù)字,但是,這也意味著一個(gè)字符"0"不通過(guò),所以我們采用下面的形式:^(0|[1-9][0-9]*)$

18? ? 3.一個(gè)0或者一個(gè)不以0開頭的數(shù)字.我們還可以允許開頭有一個(gè)負(fù)號(hào):^(0|-?[1-9][0-9]*)$

19? ? 4.這表示一個(gè)0或者一個(gè)可能為負(fù)的開頭不為0的數(shù)字.讓用戶以0開頭好了.把負(fù)號(hào)的也去掉,因?yàn)殄X總不能是負(fù)的吧.下面我們要加的是說(shuō)明可能的小數(shù)部分:^[0-9]+(.[0-9]+)?$

20? ? 5.必須說(shuō)明的是,小數(shù)點(diǎn)后面至少應(yīng)該有1位數(shù),所以"10."是不通過(guò)的,但是 "10" 和 "10.2" 是通過(guò)的:^[0-9]+(.[0-9]{2})?$

21? ? 6.這樣我們規(guī)定小數(shù)點(diǎn)后面必須有兩位,如果你認(rèn)為太苛刻了,可以這樣:^[0-9]+(.[0-9]{1,2})?$

22? ? 7.這樣就允許用戶只寫一位小數(shù).下面我們?cè)摽紤]數(shù)字中的逗號(hào)了,我們可以這樣:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$

23? ? 8.1到3個(gè)數(shù)字,后面跟著任意個(gè) 逗號(hào)+3個(gè)數(shù)字,逗號(hào)成為可選,而不是必須:^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$

24? ? 備注:這就是最終結(jié)果了,別忘了"+"可以用"*"替代如果你覺(jué)得空字符串也可以接受的話(奇怪,為什么?)最后,別忘了在用函數(shù)時(shí)去掉去掉那個(gè)反斜杠,一般的錯(cuò)誤都在這里

25 xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$

26 中文字符的正則表達(dá)式:[\u4e00-\u9fa5]

27 雙字節(jié)字符:[^\x00-\xff]? ? (包括漢字在內(nèi),可以用來(lái)計(jì)算字符串的長(zhǎng)度(一個(gè)雙字節(jié)字符長(zhǎng)度計(jì)2,ASCII字符計(jì)1))

28 空白行的正則表達(dá)式:\n\s*\r? ? (可以用來(lái)刪除空白行)

29 HTML標(biāo)記的正則表達(dá)式:<(\S*?)[^>]*>.*?|<.*? />? ? (網(wǎng)上流傳的版本太糟糕,上面這個(gè)也僅僅能部分,對(duì)于復(fù)雜的嵌套標(biāo)記依舊無(wú)能為力)

30 首尾空白字符的正則表達(dá)式:^\s*|\s*$或(^\s*)|(\s*$)? ? (可以用來(lái)刪除行首行尾的空白字符(包括空格、制表符、換頁(yè)符等等),非常有用的表達(dá)式)

31 騰訊QQ號(hào):[1-9][0-9]{4,}? ? (騰訊QQ號(hào)從10000開始)

32 中國(guó)郵政編碼:[1-9]\d{5}(?!\d)? ? (中國(guó)郵政編碼為6位數(shù)字)

33 IP地址:\d+\.\d+\.\d+\.\d+? ? (提取IP地址時(shí)有用)

附錄二 : 參考資料

正則表達(dá)式檢測(cè)工具:http://www.regexlab.com/zh/workshop.htm

http://tool.oschina.net/regex

參考文檔: http://www.regexlab.com/zh/regref.htm

http://deerchao.net/tutorials/regex/regex.htm

http://lxcnn.cnblogs.com/

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

推薦閱讀更多精彩內(nèi)容