正規表示式

2022-08-22 12:12:09 字數 4407 閱讀 5512

1.概念:正規表示式是乙個字串,使用單個字串來面熟,用來定義匹配規則,匹配一系列覅和某個jufaguize的字串,在開發中,正規表示式通常被用來檢索,替換那些符合某個規則的文字

2.正規表示式的匹配規則:明確區分大小寫

字元 x:代表的是字元x

例:匹配規則為「a」,那麼需要匹配的字串內容就是「a」

字元  \\:代表的是反斜線字元「\」

例:匹配規則為「\\」,那麼需要匹配的字串內容就是「\」

字元 \t:製表符

例:匹配規則為「\t」,那麼對應的效果就是產生乙個製表符的空間

字元 \n:換行符

例:匹配規則為"\n",那麼對應的效果就是換行,游標在原有位置的下一行

字元 \r:回車符

例:匹配規則為"\r",那麼對應的效果就是回車後的效果,游標來到下一行行首

字元類[abc]:代表的是字元a,b或c

例:匹配規則為"[abc]",那麼需要匹配的內容就是字元a,或者字元

b,或字元

c的乙個

字元類 [^abc]:代表的是除了 a、

b 或

c以外的任何字元

例:匹配規則為"[^abc]",那麼需要匹配的內容就是不是字元a,或者不是字元

b,或不是字元

c的任意乙個字元

字元類 [a-za-z]:代表的是a 到

z 或

a 到

z,兩頭的字母包括在內

例:匹配規則為"[a-za-z]",那麼需要匹配的是乙個大寫或者小寫字母

字元類[0-9]:代表的是0到9數字,兩頭的數字包括在內

例:匹配規則為"[0-9]",那麼需要匹配的是乙個數字

字元類:[a-za-z_0-9]

含義:代表的字母或者數字或者下劃線(即單詞字元

)例如:匹配規則為" [a-za-z_0-9] ",那麼需要匹配的是乙個字母或者是乙個數字或乙個下滑線

預定義字元類:.

含義:代表的是任何字元

例如:匹配規則為" . ",那麼需要匹配的是乙個任意字元。如果,就想使用 . 的話,使用匹配規則

"\\."

來實現預定義字元類:\d

含義:代表的是 0到

9數字,兩頭的數字包括在內,相當於[0-9]

例如:匹配規則為"\d ",那麼需要匹配的是乙個數字

預定義字元類:\w

含義:代表的字母或者數字或者下劃線(即單詞字元

),相當於[a-za-z_0-9]

例如:匹配規則為"\w ",,那麼需要匹配的是乙個字母或者是乙個數字或乙個下滑線

邊界匹配器:^

含義:代表的是行的開頭

例如:匹配規則為^[abc][0-9]$,那麼需要匹配的內容從[abc]這個位置開始

, 相當於左雙引號

邊界匹配器:$

含義:代表的是行的結尾

例如:匹配規則為^[abc][0-9]$,那麼需要匹配的內容以[0-9]這個結束

, 相當於右雙引號

邊界匹配器:\b

含義:代表的是單詞邊界

例如:匹配規則為"\b[abc]\b",那麼代表的是字母a或b或

c的左右兩邊需要的是非單詞字元

([a-za-z_0-9])

數量詞:x?

含義:代表的是x出現一次或一次也沒有

例如:匹配規則為"a?",那麼需要匹配的內容是乙個字元a,或者乙個

a都沒有

數量詞:x*

含義:代表的是x出現零次或多次

例如:匹配規則為"a*",那麼需要匹配的內容是多個字元a,或者乙個

a都沒有

數量詞:x+

含義:代表的是x出現一次或多次

例如:匹配規則為"a+",那麼需要匹配的內容是多個字元a,或者乙個

a數量詞:x

含義:代表的是x出現恰好 n 次

例如:匹配規則為"a",那麼需要匹配的內容是5個字元

a數量詞:x

含義:代表的是x出現至少 n 次

例如:匹配規則為"a",那麼需要匹配的內容是最少有5個字元

a數量詞:x

含義:代表的是x出現至少

n 次,但是不超過 m 次

例如:匹配規則為"a",那麼需要匹配的內容是有5個字元

a 到

8個字元a之間

3.字串類中涉及正規表示式的常用方法

boolean:matches(string regex)告知字串是否匹配給定的正規表示式

string:spliy(string regex)根據給定正規表示式的匹配拆分此字串

string:replaceall(string regex,string replacement)使用給定的replacement替換此字串所有匹配給定的正規表示式的字串

4.字串類中設計正規表示式的常用方法

public booleanmatches(string regex) //判斷字串是否匹配給定的規則;

舉例:校驗qq號碼.

1: 要求必須是5-15位數字

2: 0不能開頭

**演示:

string qq = "604154942";

string regex = "[1-9][0-9]";

boolean flag2 = qq.matches(regex);

舉例:校驗手機號碼

1:要求為11位數字

2:第1位為1,第2位為3、4、5、7、8中的乙個,後面9位為0到9之間的任意數字。

**演示:

string phone = "18800022116";

string regex = "1[34578][0-9]";

boolean flag = phone.matches(regex);

public stringsplit(string regex)  //根據給定正規表示式的匹配規則,拆分此字串;

舉例:分割出字串中的的數字

**演示:

string s = "18-22-40-65";

string regex = "-";

string result =s.split(regex);

**演示:

string s = "18 22 40 65";

string regex = " ";

string result =s.split(regex);

public stringreplaceall(string regex,string replacement) //將符合規則的字串內容,全部替換為新字串;

舉例:把文字中的數字替換成***演示:

string s = "hello12345world6789012";

string regex = "[0-9]";

string result = s.replaceall(regex, "*");

正規表示式 正規表示式 總結

非負整數 d 正整數 0 9 1 9 0 9 非正整數 d 0 負整數 0 9 1 9 0 9 整數 d 非負浮點數 d d 正浮點數 0 9 0 9 1 9 0 9 0 9 1 9 0 9 0 9 0 9 1 9 0 9 非正浮點數 d d 0 0 負浮點數 正浮點數正則式 英文本串 a za z...

正規表示式 表示式

網域名稱 a za z0 9 a za z0 9 a za z0 9 a za z0 9 interneturl a za z s 或 http w w w 手機號碼 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 號碼 x x x...

Linux正規表示式 編寫正規表示式

為了所有實用化的用途,你可以通過使用程式產生正確的結果。然而,並不意味著程式總是如你所願的那樣正確地工作。多數情況下,如果程式不能產生想要的輸出,可以斷定真正的問題 排除輸入或語法錯誤 在於如何描述想要的東西。換句話說,應該考慮糾正問題的地方是描述想要的結果的表示式。表示式不完整或者公式表示得不正確...