JAVA正則表達式語法大全

[正則表達式]文本框輸入內容控制javascript

整數或者小數:^[0-9]+\.{0,1}[0-9]{0,2}$html

只能輸入數字:"^[0-9]*$"。java

只能輸入n位的數字:"^\d{n}$"。正則表達式

只能輸入至少n位的數字:"^\d{n,}$"。函數

只能輸入m~n位的數字:。"^\d{m,n}$"this

只能輸入零和非零開頭的數字:"^(0|[1-9][0-9]*)$"。spa

只能輸入有兩位小數的正實數:"^[0-9]+(.[0-9]{2})?$"。prototype

只能輸入有1~3位小數的正實數:"^[0-9]+(.[0-9]{1,3})?$"。code

只能輸入非零的正整數:"^\+?[1-9][0-9]*$"。orm

只能輸入非零的負整數:"^\-[1-9][]0-9"*$。

只能輸入長度爲3的字符:"^.{3}$"。

只能輸入由26個英文字母組成的字符串:"^[A-Za-z]+$"。

只能輸入由26個大寫英文字母組成的字符串:"^[A-Z]+$"。

只能輸入由26個小寫英文字母組成的字符串:"^[a-z]+$"。

只能輸入由數字和26個英文字母組成的字符串:"^[A-Za-z0-9]+$"。

只能輸入由數字、26個英文字母或者下劃線組成的字符串:"^\w+$"。

驗證用戶密碼:"^[a-zA-Z]\w{5,17}$"正確格式爲:以字母開頭,長度在6~18之間,只能包含字符、數字和下劃線。

驗證是否含有^%&',;=?$\"等字符:"[^%&',;=?$\x22]+"。

只能輸入漢字:"^[\u4e00-\u9fa5]{0,}$"

驗證Email地址:"^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$"。

驗證InternetURL:"^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$"。

驗證電話號碼:"^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$"正確格式爲:"XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"。

驗證身份證號(15位或18位數字):"^\d{15}|\d{18}$"。

驗證一年的12個月:"^(0?[1-9]|1[0-2])$"正確格式爲:"01"~"09"和"1"~"12"。

驗證一個月的31天:"^((0?[1-9])|((1|2)[0-9])|30|31)$"正確格式爲;"01"~"09"和"1"~"31"。

匹配中文字符的正則表達式: [\u4e00-\u9fa5]

匹配雙字節字符(包括漢字在內):[^\x00-\xff]

應用:計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)

String.prototype.len=function(){return this.replace(/[^\x00-\xff]/g,"aa").length;}

匹配空行的正則表達式:\n[\s| ]*\r

匹配html標籤的正則表達式:<(.*)>(.*)<\/(.*)>|<(.*)\/>

匹配首尾空格的正則表達式:(^\s*)|(\s*$)

應用:javascript中沒有像vbscript那樣的trim函數,咱們就能夠利用這個表達式來實現,以下:

String.prototype.trim = function()
{
    return this.replace(/(^\s*)|(\s*$)/g, "");
}

利用正則表達式分解和轉換IP地址:

下面是利用正則表達式匹配IP地址,並將IP地址轉換成對應數值的Javascript程序:

function IP2V(ip)
{
    re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //匹配IP地址的正則表達式
    if(re.test(ip))
    {
        return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
    }
    else
    {
        throw new Error("Not a valid IP address!")
    }
}

不過上面的程序若是不用正則表達式,而直接用split函數來分解可能更簡單,程序以下:

var ip="10.100.20.168"
ip=ip.split(".")
alert("IP值是:"+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1))

匹配Email地址的正則表達式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*

匹配網址URL的正則表達式:http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?


利用正則表達式限制網頁表單裏的文本框輸入內容:

用正則表達式限制只能輸入中文:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))"

用正則表達式限制只能輸入全角字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))"

用正則表達式限制只能輸入數字:onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"

用正則表達式限制只能輸入數字和英文:onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"

<input onkeyup="value=value.replace(/[^\u4E00-\u9FA5\w]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5\w]/g,''))" value="容許下劃線,數字字母和漢字">

<script language="javascript">
if (document.layers)//觸發鍵盤事件
document.captureEvents(Event.KEYPRESS)
function xz(thsv,nob){
if(nob=="2"){
window.clipboardData.setData("text","")
alert("避免非法字符輸入,請勿複製字符");
return false;
}
if (event.keyCode!=8 && event.keyCode!=16 && event.keyCode!=37 && event.keyCode!=38 && event.keyCode!=39 && event.keyCode!=40){
thsvv=thsv.value;//輸入的值
thsvs=thsvv.substring(thsvv.length-1);//輸入的最後一個字符
//thsvss=thsvv.substring(0,thsvv.length-1);//去掉最後一個錯誤字符
if (!thsvs.replace(/[^\u4E00-\u9FA5\w]/g,'') || event.keyCode==189){//正則除去符號和下劃線 key
thsv.value='請勿輸入非法符號 ['+thsvs+']';
alert('請勿輸入非法符號 ['+thsvs+']');
thsv.value="";
return false;
}
}
}
</script>

<input onkeyup="xz(this,1)" onPaste="xz(this,2)" value="">容許數字字母和漢字

<script language="javascript">
<!--
function MaxLength(field,maxlimit){
var j = field.value.replace(/[^\x00-\xff]/g,"**").length;
//alert(j);
var tempString=field.value;
var tt="";
if(j > maxlimit){
for(var i=0;i<maxlimit;i++){
if(tt.replace(/[^\x00-\xff]/g,"**").length < maxlimit)
tt = tempString.substr(0,i+1);
else
break;
}
if(tt.replace(/[^\x00-\xff]/g,"**").length > maxlimit)
tt=tt.substr(0,tt.length-1);
field.value = tt;
}else{
;
}
}
</script>

單行文本框控制<br />

<INPUT type="text" id="Text1" name="Text1" onpropertychange="MaxLength(this, 5)"><br />

多行文本框控制:<br />

<TEXTAREA rows="14"
cols="39" id="Textarea1" name="Textarea1" onpropertychange="MaxLength(this, 15)"></TEXTAREA><br />

控制表單內容只能輸入數字,中文....

<script>
function test()  
{
if(document.a.b.value.length>50)
{
alert("不能超過50個字符!");
document.a.b.focus();
return false;
}
}
</script>
<form name=a onsubmit="return test()">
<textarea name="b" cols="40" wrap="VIRTUAL" rows="6"></textarea>
<input type="submit" name="Submit" value="check">
</form>

只能是漢字

<input onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')">

只能是英文字符

<script language=javascript>
function onlyEng()
{
if(!(event.keyCode>=65&&event.keyCode<=90))
    event.returnValue=false;
}
</script>
<input onkeydown="onlyEng();">
<input name="coname" type="text" size="50" maxlength="35" class="input2" onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))">

只能是數字

<script language=javascript>
function onlyNum()
{
if(!((event.keyCode>=48&&event.keyCode<=57)||(event.keyCode>=96&&event.keyCode<=105)))
//考慮小鍵盤上的數字鍵
    event.returnValue=false;
}
</script>

<input onkeydown="onlyNum();">

只能是英文字符和數字

<input onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))">

驗證爲email格式

<SCRIPT LANGUAGE=Javascript RUNAT=Server>
function isEmail(strEmail) {
if (strEmail.search(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/) != -1)
return true;
else
alert("oh");
}
</SCRIPT>

<input type=text onblur=isEmail(this.value)>

屏蔽關鍵字(sex , fuck) - 已修改

<script language="JavaScript1.2">
function test() {
if((a.b.value.indexOf ("sex") == 0)||(a.b.value.indexOf ("fuck") == 0)){
    alert("五講四美三熱愛");
    a.b.focus();
    return false;}
}
</script>
<form name=a onsubmit="return test()">
<input type=text name=b>
<input type="submit" name="Submit" value="check">
</form>


限制文本框裏只能輸入數字

<input onkeyup="if(event.keyCode !=37 && event.keyCode != 39) value=value.replace(/\D/g,'');"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/\D/g,''))"> 

<PIXTEL_MMI_EBOOK_2005>2                     </PIXTEL_MMI_EBOOK_2005>


JAVA正則表達式語法(轉)

正則表達式語法

正則表達式是一種文本模式,包括普通字符(例如,a 到 z 之間的字母)和特殊字符(稱爲「元字符」)。模式描述在搜索文本時要匹配的一個或多個字符串。

正則表達式示例

表達式 匹配 

/^\s*$/

匹配空行。

/\d{2}-\d{5}/

驗證由兩位數字、一個連字符再加 5 位數字組成的 ID 號。

/<\s*(\S+)(\s[^>]*)?>[\s\S]*<\s*\/\1\s*>/

匹配 HTML 標記。

下表包含了元字符的完整列表以及它們在正則表達式上下文中的行爲:

字符 說明


\    將下一字符標記爲特殊字符、文本、反向引用或八進制轉義符。例如,「n」匹配字符「n」。「\n」匹配換行符。序列「\\」匹配「\」,「\(」匹配「(」。

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

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

*    零次或屢次匹配前面的字符或子表達式。例如,zo* 匹配「z」和「zoo」。* 等效於 {0,}。

+    一次或屢次匹配前面的字符或子表達式。例如,「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}    M 和 n 是非負整數,其中 n <= m。匹配至少 n 次,至多 m 次。例如,「o{1,3}」匹配「fooooood」中的頭三個 o。'o{0,1}' 等效於 'o?'。注意:您不能將空格插入逗號和數字之間。

?    當此字符緊隨任何其餘限定符(*、+、?、{n}、{n,}、{n,m})以後時,匹配模式是「非貪心的」。「非貪心的」模式匹配搜索到的、儘量短的字符串,而默認的「貪心的」模式匹配搜索到的、儘量長的字符串。例如,在字符串「oooo」中,「o+?」只匹配單個「o」,而「o+」匹配全部「o」。

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

(pattern)    匹配 pattern 並捕獲該匹配的子表達式。可使用 $0…$9 屬性從結果「匹配」集合中檢索捕獲的匹配。若要匹配括號字符 ( ),請使用「\(」或者「\)」。

(?:pattern)    匹配 pattern 但不捕獲該匹配的子表達式,即它是一個非捕獲匹配,不存儲供之後使用的匹配。這對於用「or」字符 (|) 組合模式部件的狀況頗有用。例如,'industr(?:y|ies) 是比 'industry|industries' 更經濟的表達式。

(?=pattern)    執行正向預測先行搜索的子表達式,該表達式匹配處於匹配 pattern 的字符串的起始點的字符串。它是一個非捕獲匹配,即不能捕獲供之後使用的匹配。例如,'Windows (?=95|98|NT|2000)' 匹配「Windows 2000」中的「Windows」,但不匹配「Windows 3.1」中的「Windows」。預測先行不佔用字符,即發生匹配後,下一匹配的搜索緊隨上一匹配以後,而不是在組成預測先行的字符後。

(?!pattern)    執行反向預測先行搜索的子表達式,該表達式匹配不處於匹配 pattern 的字符串的起始點的搜索字符串。它是一個非捕獲匹配,即不能捕獲供之後使用的匹配。例如,'Windows (?!95|98|NT|2000)' 匹配「Windows 3.1」中的 「Windows」,但不匹配「Windows 2000」中的「Windows」。預測先行不佔用字符,即發生匹配後,下一匹配的搜索緊隨上一匹配以後,而不是在組成預測先行的字符後。

x|y    匹配 x 或 y。例如,'z|food' 匹配「z」或「food」。'(z|f)ood' 匹配「zood」或「food」。

[xyz]    字符集。匹配包含的任一字符。例如,「[abc]」匹配「plain」中的「a」。

[^xyz]    反向字符集。匹配未包含的任何字符。例如,「[^abc]」匹配「plain」中的「p」。

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

[^a-z]    反向範圍字符。匹配不在指定的範圍內的任何字符。例如,「[^a-z]」匹配任何不在「a」到「z」範圍內的任何字符。

\b    匹配一個字邊界,即字與空格間的位置。例如,「er\b」匹配「never」中的「er」,但不匹配「verb」中的「er」。

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

\cx    匹配 x 指示的控制字符。例如,\cM 匹配 Control-M 或回車符。x 的值必須在 A-Z 或 a-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_]」等效。

\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 匹配八進制值 nm,其中 n 和 m 是八進制數字 (0-7)。

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

\un    匹配 n,其中 n 是以四位十六進制數表示的 Unicode 字符。例如,\u00A9 匹配版權符號 (?)。

相關文章
相關標籤/搜索