正則表達式基本語法


以下摘自MSDN

————————————————————————————————————————————————————————————————————————————

“正則表達式”描述在搜索文本正文時要匹配的一個或多個字符串。 該表達式可用作一個將字符模式與要搜索的字符串相匹配的模板。

正則表達式包括普通字符(例如,a 到 z 之間的字母)和特殊字符(稱為“元字符”)。

特殊字符

下表包含了單字符元字符的列表以及它們在正則表達式中的行為。
注意注意

若要匹配這些特殊字符之一,必須首先轉義字符,即,在字符前面加反斜杠字符 (\)。 例如,若要搜索“+”文本字符,可使用表達式“\+”。

 

元字符

行為

示例

*

零次或多次匹配前面的字符或子表達式。

等效於 {0,}。

zo* 與“z”和“zoo”匹配。

+

一次或多次匹配前面的字符或子表達式。

等效於 {1,}。

zo+ 與“zo”和“zoo”匹配,但與“z”不匹配。

?

零次或一次匹配前面的字符或子表達式。

等效於 {0,1}。

當 ? 緊隨任何其他限定符(*、+、?、{n}、{n,} 或 {n,m})之后時,匹配模式是非貪婪的。 非貪婪模式匹配搜索到的、盡可能少的字符串, 而默認的貪婪模式匹配搜索到的、盡可能多的字符串。

zo? 與“z”和“zo”匹配,但與“zoo”不匹配。

o+? 只與“oooo”中的單個“o”匹配,而 o+ 與所有“o”匹配。

do(es)? 與“do”或“does”中的“do”匹配。

^

匹配搜索字符串開始的位置。 如果標志中包括 m(多行搜索)字符,^ 還將匹配 \n 或 \r 后面的位置。

如果將 ^ 用作括號表達式中的第一個字符,則會對字符集求反。

^\d{3} 與搜索字符串開始處的 3 個數字匹配。

[^abc] 與除 a、b 和 c 以外的任何字符匹配。

$

匹配搜索字符串結尾的位置。 如果標志中包括 m(多行搜索)字符,^ 還將匹配 \n 或 \r 前面的位置。

\d{3}$ 與搜索字符串結尾處的 3 個數字匹配。

.

匹配除換行符 \n 之外的任何單個字符。 若要匹配包括 \n 在內的任意字符,請使用諸如 [\s\S] 之類的模式。

a.c 與“abc”、“a1c”和“a-c”匹配。

[]

標記括號表達式的開始和結尾。

[1-4] 與“1”、“2”、“3”或“4”匹配。 [^aAeEiIoOuU]與任何非元音字符匹配。

{}

標記限定符表達式的開始和結尾。

a{2,3} 與“aa”和“aaa”匹配。

()

標記子表達式的開始和結尾。 可以保存子表達式以備將來之用。

A(\d) 與“A0”至“A9”匹配。 保存該數字以備將來之用。

|

指示在兩個或多個項之間進行選擇。

z|food 與“z”或“food”匹配。 (z|f)ood與“zood”或“food”匹配。

/

表示 JScript 中的文本正則表達式模式的開始或結尾。 在第二個“/”后添加單字符標志可以指定搜索行為。

/abc/gi 是與“abc”匹配的 JScript 文本正則表達式。g(全局)標志指定查找模式的所有匹配項,i(忽略大小寫)標志使搜索不區分大小寫。

\

將下一字符標記為特殊字符、文本、反向引用或八進制轉義符。

\n 與換行符匹配。 \( 與“(”匹配。 \\ 與“\”匹配。

大多數特殊字符在括號表達式內出現時失去它們的意義,並表示普通字符。 有關更多信息,請參見匹配字符的列表中的“括號表達式中的字符”。

元字符

下表包含了多字符元字符的列表以及它們在正則表達式中的行為。
 

元字符

行為

示例

\b

與一個字邊界匹配;即字與空格間的位置。

er\b 與“never”中的“er”匹配,但與“verb”中的“er”不匹配。

\B

非邊界字匹配。

er\B 與“verb”中的“er”匹配,但與“never”中的“er”不匹配。

\d

數字字符匹配。

等效於 [0-9]。

在搜索字符串“12 345”中,\d{2}與“12”和“34”匹配。 \d與“1”、“2”、“3”、“4”和“5”匹配。

\D

非數字字符匹配。

等效於 [^0-9]。

\D+ 與“abc123 def”中的“abc”和“def”匹配。

\w

與以下任意字符匹配:A-Z、a-z、0-9 和下划線。

等效於 [A-Za-z0-9_]。

在搜索字符串“The quick brown fox…”中,\w+與“The”、“quick”、“brown”和“fox”匹配。

\W

與除 A-Z、a-z、0-9 和下划線以外的任意字符匹配。

等效於 [^A-Za-z0-9_]。

在搜索字符串“The quick brown fox…”中,\W+ 與“…”和所有空格匹配。

[xyz]

字符集。 與任何一個指定字符匹配。

[abc] 與“plain”中的“a”匹配。

[^xyz]

反向字符集。 與未指定的任何字符匹配。

[^abc] 與“plain”中的“p”、“l”、“i”和“n”匹配。

[a-z]

字符范圍。 匹配指定范圍內的任何字符。

[a-z] 與“a”到“z”范圍內的任何小寫字母字符匹配。

[^a-z]

反向字符范圍。 與不在指定范圍內的任何字符匹配。

[^a-z] 與不在范圍“a”到“z”內的任何字符匹配。

{n}

正好匹配 n 次。 n 是非負整數。

o{2} 與“Bob”中的“o”不匹配,但與“food”中的兩個“o”匹配。

{n,}

至少匹配 n 次。 n 是非負整數。

* 與 {0,} 相等。

+ 與 {1,} 相等。

o{2,} 與“Bob”中的“o”不匹配,但與“foooood”中的所有“o”匹配。

{n,m}

匹配至少 n 次,至多 m 次。 n 和 m 是非負整數,其中 n <= m。 逗號和數字之間不能有空格。

? 與 {0,1} 相等。

在搜索字符串“1234567”中,\d{1,3}與“123”、“456”和“7”匹配。

(模式)

模式 匹配並保存匹配項。 您可以從由 JScript 中的 exec Method返回的數組元素中檢索保存的匹配項。 若要匹配括號字符 ( ),請使用“\(”或者“\)”。

(Chapter|Section) [1-9] 與“Chapter 5”匹配,保存“Chapter”以備將來之用。

(?:模式)

模式 匹配,但不保存匹配項;即不會存儲匹配項以備將來之用。 這對於用“or”字符 (|) 組合模式部件的情況很有用。

industr(?:y|ies) 與 industry|industries相等。

(?=模式)

正預測先行。 找到一個匹配項后,將在匹配文本之前開始搜索下一個匹配項。 不會保存匹配項以備將來之用。

^(?=.*\d).{4,8}$ 對密碼應用以下限制:其長度必須介於 4 到 8 個字符之間,並且必須至少包含一個數字。

在該模式中,.*\d 查找后跟有數字的任意多個字符。 對於搜索字符串“abc3qr”,這與“abc3”匹配。

從該匹配項之前(而不是之后)開始,.{4,8} 與包含 4-8 個字符的字符串匹配。這與“abc3qr”匹配。

^ 和 $ 指定搜索字符串的開始和結束位置。 這將在搜索字符串包含匹配字符之外的任何字符時阻止匹配。

(?!模式)

負預測先行。 匹配與模式 不匹配的搜索字符串。 找到一個匹配項后,將在匹配文本之前開始搜索下一個匹配項。 不會保存匹配項以備將來之用。

\b(?!th)\w+\b 與不以“th”開頭的單詞匹配。

在該模式中,\b 與一個字邊界匹配。 對於搜索字符串“ quick ”,這與第一個空格匹配。 (?!th) 與非“th”字符串匹配。這與“qu”匹配。

從該匹配項開始,\w+ 與一個字匹配。這與“quick”匹配。

\cx

匹配 x 指示的控制字符。 x 的值必須在 A-Z 或 a-z 范圍內。 如果不是這樣,則假定 c 就是文本“c”字符本身。

\cM 與 Ctrl+M 或一個回車符匹配。

\xn

匹配 n,此處的 n 是一個十六進制轉義碼。 十六進制轉義碼必須正好是兩位數長。允許在正則表達式中使用 ASCII 代碼。

\x41 與“A”匹配。 \x041 等效於后跟有“1”的“\x04”(因為 n 必須正好是兩位數)。

\num

匹配 num,此處的 num 是一個正整數。 這是對已保存的匹配項的引用。

(.)\1 與兩個連續的相同字符匹配。

\n

標識一個八進制轉義碼或反向引用。 如果 \n 前面至少有 n 個捕獲子表達式,那么 n是反向引用。 否則,如果 n 是八進制數 (0-7),那么 n 是八進制轉義碼。

(\d)\1 與兩個連續的相同數字匹配。

\nm

標識一個八進制轉義碼或反向引用。 如果 \nm 前面至少有 nm 個捕獲子表達式,那么 nm 是反向引用。 如果 \nm 前面至少有 n 個捕獲子表達式,則 n 是反向引用,后面跟有文本 m。 如果上述情況都不存在,當 n 和 m 是八進制數字 (0-7) 時,\nm 匹配八進制轉義碼 nm。

\11 與制表符匹配。

\nml

當 n 是八進制數字 (0-3),m 和 l 是八進制數字 (0-7) 時,匹配八進制轉義碼 nml。

\011 與制表符匹配。

\un

匹配 n,其中 n 是以四位十六進制數表示的 Unicode 字符。

\u00A9 與版權符號 (©) 匹配。

非打印字符

下表包含表示非打印字符的轉義序列。
 

字符

匹配

等效於

\f

換頁符。

\x0c 和 \cL

\n

換行符。

\x0a 和 \cJ

\r

回車符。

\x0d 和 \cM

\s

任何空白字符。 其中包括空格、制表符和換頁符。

[ \f\n\r\t\v]

\S

任何非空白字符。

[^ \f\n\r\t\v]

\t

Tab 字符。

\x09 和 \cI

\v

垂直制表符。

\x0b 和 \cK

優先級順序

正則表達式的計算方式與算術表達式非常類似;即從左到右進行計算,並遵循優先級順序。

下表按從高到低的順序包含了正則表達式運算符的優先級順序。

 

運算符

說明

\

轉義符

(), (?:), (?=), []

括號和中括號

*、+、?、{n}、{n,}、{n,m}

限定符

^、$、\任何元字符

定位點和序列

|

替換

字符具有高於替換運算符的優先級,例如,允許“m|food”匹配“m”或“food”。

————————————————————————————————————————————————————————————————————————————

 

一.正則表達式基本語法

兩個特殊的符號'^''$'。他們的作用是分別指出一個字符串的開始和結束。例子如下:

"^The":表示所有以"The"開始的字符串("There""The cat"等);
"of despair$":表示所以以"of despair"結尾的字符串;
"^abc$":表示開始和結尾都是"abc"的字符串——呵呵,只有"abc"自己了;
"notice":表示任何包含"notice"的字符串。

象最后那個例子,如果你不使用兩個特殊字符,你就在表示要查找的串在被查找串的任意部分——你並
不把它定位在某一個頂端。

其它還有'*''+''?'這三個符號,表示一個或一序列字符重復出現的次數。它們分別表示沒有或
更多一次或更多還有沒有或一次。下面是幾個例子:

"ab*":表示一個字符串有一個a后面跟着零個或若干個b。("a", "ab", "abbb",……);
"ab+":表示一個字符串有一個a后面跟着至少一個b或者更多;
"ab?":表示一個字符串有一個a后面跟着零個或者一個b
"a?b+$":表示在字符串的末尾有零個或一個a跟着一個或幾個b

你也可以使用范圍,用大括號括起,用以表示重復次數的范圍。

"ab{2}":表示一個字符串有一個a跟着2b"abb");
"ab{2,}":表示一個字符串有一個a跟着至少2b
"ab{3,5}":表示一個字符串有一個a跟着35b

請注意,你必須指定范圍的下限(如:"{0,2}"而不是"{,2}")。還有,你可能注意到了,'*''+'
'?'相當於"{0,}""{1,}""{0,1}"
還有一個'¦',表示操作:

"hi¦hello":表示一個字符串里有"hi"或者"hello"
"(b¦cd)ef":表示"bef""cdef"
"(a¦b)*c":表示一串"a""b"混合的字符串后面跟一個"c"

'.'可以替代任何字符:

"a.[0-9]":表示一個字符串有一個"a"后面跟着一個任意字符和一個數字;
"^.{3}$":表示有任意三個字符的字符串(長度為3個字符);

方括號表示某些字符允許在一個字符串中的某一特定位置出現:

"[ab]":表示一個字符串有一個"a""b"(相當於"a¦b");
"[a-d]":表示一個字符串包含小寫的'a''d'中的一個(相當於"a¦b¦c¦d"或者"[abcd]");
"^[a-zA-Z]":表示一個以字母開頭的字符串;
"[0-9]%":表示一個百分號前有一位的數字;
",[a-zA-Z0-9]$":表示一個字符串以一個逗號后面跟着一個字母或數字結束。

你也可以在方括號里用'^'表示不希望出現的字符,'^'應在方括號里的第一位。(如:"%[^a-zA-Z]%"
示兩個百分號中不應該出現字母)。

為了逐字表達,你必須在"^.$()¦*+?{\"這些字符前加上轉移字符'\'

請注意在方括號中,不需要轉義字符。



二.正則表達式驗證控制文本框的輸入字符類型
1.只能輸入數字和英文的: 
<input onkeyup="value=value.replace(/[\W]/g,'') " onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))" ID="Text1" NAME="Text1">

2.只能輸入數字的: 
<input onkeyup="value=value.replace(/[^\d]/g,'') " onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))" ID="Text2" NAME="Text2">

3.只能輸入全角的: 
<input onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))" ID="Text3" NAME="Text3">

4.只能輸入漢字的: 
<input onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))" ID="Text4" NAME="Text4">


3.正則表達式的應用實例通俗說明
 

*******************************************************************************

//校驗是否全由數字組成

/^[0-9]{1,20}$/

 

^ 表示打頭的字符要匹配緊跟^后面的規則

$ 表示打頭的字符要匹配緊靠$前面的規則

[ ] 中的內容是可選字符集

[0-9] 表示要求字符范圍在0-9之間

{1,20}表示數字字符串長度合法為1到20,即為[0-9]中的字符出現次數的范圍是1到20次。

 

/^ 和 $/成對使用應該是表示要求整個字符串完全匹配定義的規則,而不是只匹配字符串中的一個子串。

 

*******************************************************************************

//校驗登錄名:只能輸入5-20個以字母開頭、可帶數字、“_”、“.”的字串

/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/

 

^[a-zA-Z]{1} 表示第一個字符要求是字母。

([a-zA-Z0-9]|[._]){4,19} 表示從第二位開始(因為它緊跟在上個表達式后面)的一個長度為4到9位的字符串,它要求是由大小寫字母、數字或者特殊字符集[._]組成。

 

*******************************************************************************

//校驗用戶姓名:只能輸入1-30個以字母開頭的字串

/^[a-zA-Z]{1,30}$/

 

*******************************************************************************

//校驗密碼:只能輸入6-20個字母、數字、下划線

/^(\w){6,20}$/

 

\w:用於匹配字母,數字或下划線字符

 

*******************************************************************************

//校驗普通電話、傳真號碼:可以“+”或數字開頭,可含有“-” 和 “ ”

/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/

 

\d:用於匹配從0到9的數字;

“?”元字符規定其前導對象必須在目標對象中連續出現零次或一次

 

可以匹配的字符串如:+123 -999 999 ; +123-999 999 ;123 999 999 ;+123 999999等

 

 

 

 

 

 

*******************************************************************************

//校驗URL

/^http[s]{0,1}:\/\/.+$/ 或 /^http[s]{0,1}:\/\/.{1,n}$/ (表示url串的長度為length(“https://”) + n )

 

\ / :表示字符“/”。

. 表示所有字符的集

+ 等同於{1,},就是1到正無窮吧。

 

*******************************************************************************

//校驗純中文字符

/^[\u4E00-\u9FA5]+$/

 

[\u4E00-\u9FA5] :估計是中文字符集的范圍吧

 

以上表達式均在下面的javascript中測試通過

 

 

4.常用正則表達式
 "^\d+$"  //非負整數(正整數 + 0) 

"^[0-9]*[1-9][0-9]*$"  //正整數 
"^((-\d+)|(0+))$"  //非正整數(負整數 + 0) 
"^-[0-9]*[1-9][0-9]*$"  //負整數 
"^-?\d+$"    //整數 
"^\d+(\.\d+)?$"  //非負浮點數(正浮點數 + 0) 
"^(([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+)?))$"  //非正浮點數(負浮點數 + 0) 
"^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //負浮點數 
"^(-?\d+)(\.\d+)?$"  //浮點數 
"^[A-Za-z]+$"  //由26個英文字母組成的字符串 
"^[A-Z]+$"  //由26個英文字母的大寫組成的字符串 
"^[a-z]+$"  //由26個英文字母的小寫組成的字符串 
"^[A-Za-z0-9]+$"  //由數字和26個英文字母組成的字符串 
"^\w+$"  //由數字、26個英文字母或者下划線組成的字符串 
"^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$"    //email地址 
"^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$"  //url
/^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$/   //  年-月-日
/^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/   // 月/日/年
"^([w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$"   //Emil
"(d+-)?(d{4}-?d{7}|d{3}-?d{8}|^d{7,8})(-d+)?"     //電話號碼
"^(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5])$"   //IP地址

 

^([0-9A-F]{2})(-[0-9A-F]{2}){5}$   //MAC地址的正則表達式
^[-+]?\d+(\.\d+)?$  //值類型正則表達式

1.正則表達式基本語法

兩個特殊的符號'^''$'。他們的作用是分別指出一個字符串的開始和結束。例子如下:

"^The":表示所有以"The"開始的字符串("There""The cat"等);
"of despair$":表示所以以"of despair"結尾的字符串;
"^abc$":表示開始和結尾都是"abc"的字符串——呵呵,只有"abc"自己了;
"notice":表示任何包含"notice"的字符串。

象最后那個例子,如果你不使用兩個特殊字符,你就在表示要查找的串在被查找串的任意部分——你並
不把它定位在某一個頂端。

其它還有'*''+''?'這三個符號,表示一個或一序列字符重復出現的次數。它們分別表示沒有或
更多一次或更多還有沒有或一次。下面是幾個例子:

"ab*":表示一個字符串有一個a后面跟着零個或若干個b。("a", "ab", "abbb",……);
"ab+":表示一個字符串有一個a后面跟着至少一個b或者更多;
"ab?":表示一個字符串有一個a后面跟着零個或者一個b
"a?b+$":表示在字符串的末尾有零個或一個a跟着一個或幾個b

你也可以使用范圍,用大括號括起,用以表示重復次數的范圍。

"ab{2}":表示一個字符串有一個a跟着2b"abb");
"ab{2,}":表示一個字符串有一個a跟着至少2b
"ab{3,5}":表示一個字符串有一個a跟着35b

請注意,你必須指定范圍的下限(如:"{0,2}"而不是"{,2}")。還有,你可能注意到了,'*''+'
'?'相當於"{0,}""{1,}""{0,1}"
還有一個'¦',表示操作:

"hi¦hello":表示一個字符串里有"hi"或者"hello"
"(b¦cd)ef":表示"bef""cdef"
"(a¦b)*c":表示一串"a""b"混合的字符串后面跟一個"c"

'.'可以替代任何字符:

"a.[0-9]":表示一個字符串有一個"a"后面跟着一個任意字符和一個數字;
"^.{3}$":表示有任意三個字符的字符串(長度為3個字符);

方括號表示某些字符允許在一個字符串中的某一特定位置出現:

"[ab]":表示一個字符串有一個"a""b"(相當於"a¦b");
"[a-d]":表示一個字符串包含小寫的'a''d'中的一個(相當於"a¦b¦c¦d"或者"[abcd]");
"^[a-zA-Z]":表示一個以字母開頭的字符串;
"[0-9]%":表示一個百分號前有一位的數字;
",[a-zA-Z0-9]$":表示一個字符串以一個逗號后面跟着一個字母或數字結束。

你也可以在方括號里用'^'表示不希望出現的字符,'^'應在方括號里的第一位。(如:"%[^a-zA-Z]%"
示兩個百分號中不應該出現字母)。

為了逐字表達,你必須在"^.$()¦*+?{\"這些字符前加上轉移字符'\'

請注意在方括號中,不需要轉義字符。



2.正則表達式驗證控制文本框的輸入字符類型
1.只能輸入數字和英文的: 
<input onkeyup="value=value.replace(/[\W]/g,'') " onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))" ID="Text1" NAME="Text1">

2.只能輸入數字的: 
<input onkeyup="value=value.replace(/[^\d]/g,'') " onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))" ID="Text2" NAME="Text2">

3.只能輸入全角的: 
<input onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))" ID="Text3" NAME="Text3">

4.只能輸入漢字的: 
<input onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))" ID="Text4" NAME="Text4">


3.正則表達式的應用實例通俗說明
 

*******************************************************************************

//校驗是否全由數字組成

/^[0-9]{1,20}$/

 

^ 表示打頭的字符要匹配緊跟^后面的規則

$ 表示打頭的字符要匹配緊靠$前面的規則

[ ] 中的內容是可選字符集

[0-9] 表示要求字符范圍在0-9之間

{1,20}表示數字字符串長度合法為1到20,即為[0-9]中的字符出現次數的范圍是1到20次。

 

/^ 和 $/成對使用應該是表示要求整個字符串完全匹配定義的規則,而不是只匹配字符串中的一個子串。

 

*******************************************************************************

//校驗登錄名:只能輸入5-20個以字母開頭、可帶數字、“_”、“.”的字串

/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/

 

^[a-zA-Z]{1} 表示第一個字符要求是字母。

([a-zA-Z0-9]|[._]){4,19} 表示從第二位開始(因為它緊跟在上個表達式后面)的一個長度為4到9位的字符串,它要求是由大小寫字母、數字或者特殊字符集[._]組成。

 

*******************************************************************************

//校驗用戶姓名:只能輸入1-30個以字母開頭的字串

/^[a-zA-Z]{1,30}$/

 

*******************************************************************************

//校驗密碼:只能輸入6-20個字母、數字、下划線

/^(\w){6,20}$/

 

\w:用於匹配字母,數字或下划線字符

 

*******************************************************************************

//校驗普通電話、傳真號碼:可以“+”或數字開頭,可含有“-” 和 “ ”

/^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/

 

\d:用於匹配從0到9的數字;

“?”元字符規定其前導對象必須在目標對象中連續出現零次或一次

 

可以匹配的字符串如:+123 -999 999 ; +123-999 999 ;123 999 999 ;+123 999999等

 

 

 

 

 

 

*******************************************************************************

//校驗URL

/^http[s]{0,1}:\/\/.+$/ 或 /^http[s]{0,1}:\/\/.{1,n}$/ (表示url串的長度為length(“https://”) + n )

 

\ / :表示字符“/”。

. 表示所有字符的集

+ 等同於{1,},就是1到正無窮吧。

 

*******************************************************************************

//校驗純中文字符

/^[\u4E00-\u9FA5]+$/

 

[\u4E00-\u9FA5] :估計是中文字符集的范圍吧

 

以上表達式均在下面的javascript中測試通過

 

<html>

<script language="JavaScript">

<!--

function regx(r,s)

{

       if (r == null || r == ""){

              return false;

       }

       var patrn= new RegExp(r);

       if (patrn.exec(s))

              return true

       return false

}

 

-->

</script>

<body>

<form>

       規則表達式 : <input type="input" name="regxStr" value="" > (填寫/ /之間的表達式)

<br>

       校驗字符串 : <input type="input" name="str" value="" >

 

       <input type="button" name="match" value="匹配" onClick="alert(regx(regxStr.value,str.value));">

</form>

</body>

</html>

4.正則表達式應用
 

"^\d+$"  //非負整數(正整數 + 0) 
"^[0-9]*[1-9][0-9]*$"  //正整數 
"^((-\d+)|(0+))$"  //非正整數(負整數 + 0) 
"^-[0-9]*[1-9][0-9]*$"  //負整數 
"^-?\d+$"    //整數 
"^\d+(\.\d+)?$"  //非負浮點數(正浮點數 + 0) 
"^(([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+)?))$"  //非正浮點數(負浮點數 + 0) 
"^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //負浮點數 
"^(-?\d+)(\.\d+)?$"  //浮點數 
"^[A-Za-z]+$"  //由26個英文字母組成的字符串 
"^[A-Z]+$"  //由26個英文字母的大寫組成的字符串 
"^[a-z]+$"  //由26個英文字母的小寫組成的字符串 
"^[A-Za-z0-9]+$"  //由數字和26個英文字母組成的字符串 
"^\w+$"  //由數字、26個英文字母或者下划線組成的字符串 
"^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$"    //email地址 
"^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$"  //url
/^(d{2}|d{4})-((0([1-9]{1}))|(1[1|2]))-(([0-2]([1-9]{1}))|(3[0|1]))$/   //  年-月-日
/^((0([1-9]{1}))|(1[1|2]))/(([0-2]([1-9]{1}))|(3[0|1]))/(d{2}|d{4})$/   // 月/日/年
"^([w-.]+)@(([[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.)|(([w-]+.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(]?)$"   //Emil
"(d+-)?(d{4}-?d{7}|d{3}-?d{8}|^d{7,8})(-d+)?"     //電話號碼
"^(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5])$"   //IP地址

^([0-9A-F]{2})(-[0-9A-F]{2}){5}$   //MAC地址的正則表達式
^[-+]?\d+(\.\d+)?$  //值類型正則表達式


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM