麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

一些常用的正則表達式大全

2019-11-17 04:12:13
字體:
來源:轉載
供稿:網友

匹配中文字符的正則表達式:
 程序代碼
[/u4e00-/u9fa5]

評注:匹配中文還真是個頭疼的事,有了這個表達式就好辦了

匹配雙字節字符(包括漢字在內):
 程序代碼
[^/x00-/xff]

評注:可以用來計算字符串的長度(一個雙字節字符長度計2,ASCII字符計1)

匹配空白行的正則表達式:
 程序代碼
/n/s*/r

評注:可以用來刪除空白行

匹配HTML標記的正則表達式:
 程序代碼
<(/S*?)[^>]*>.*?|<.*? />

評注:網上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對于復雜的嵌套標記依舊無能為力

匹配首尾空白字符的正則表達式:
 程序代碼
^/s*|/s*$

評注:可以用來刪除行首行尾的空白字符(包括空格、制表符、換頁符等等),非常有用的表達式

匹配Email地址的正則表達式:
 程序代碼
/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*

評注:表單驗證時很實用

匹配網址URL的正則表達式:
 程序代碼
[a-zA-z]+://[^/s]*

評注:網上流傳的版本功能很有限,上面這個基本可以滿足需求


匹配二級或多級域名的主域名
([a-z0-9][a-z0-9/-]*?/.(?:com|cn|net|org|gov|info|la|cc|co)(?:/.(?:cn|jp))?)$

匹配帳號是否合法(字母開頭,允許5-16字節,允許字母數字下劃線):
 程序代碼
^[a-zA-Z][a-zA-Z0-9_]{4,15}$

評注:表單驗證時很實用

匹配國內電話號碼:
 程序代碼
/d{3}-/d{8}|/d{4}-/d{7}

評注:匹配形式如 0511-4405222 或 021-87888822

匹配騰訊QQ號:
 程序代碼
[1-9][0-9]{4,}

評注:騰訊QQ號從10000開始

匹配中國郵政編碼:
 程序代碼
[1-9]/d{5}(?!/d)

評注:中國郵政編碼為6位數字

匹配身份證:
 程序代碼
/d{15}|/d{18}

評注:中國的身份證為15位或18位

匹配ip地址:
 程序代碼
/d+/./d+/./d+/./d+

評注:提取ip地址時有用

匹配特定數字:

 程序代碼
^[1-9]/d*$    //匹配正整數
^-[1-9]/d*$   //匹配負整數
^-?[1-9]/d*$   //匹配整數
^[1-9]/d*|0$  //匹配非負整數(正整數 + 0)
^-[1-9]/d*|0$   //匹配非正整數(負整數 + 0)
^[1-9]/d*/./d*|0/./d*[1-9]/d*$   //匹配正浮點數
^-([1-9]/d*/./d*|0/./d*[1-9]/d*)$  //匹配負浮點數
^-?([1-9]/d*/./d*|0/./d*[1-9]/d*|0?/.0+|0)$  //匹配浮點數
^[1-9]/d*/./d*|0/./d*[1-9]/d*|0?/.0+|0$   //匹配非負浮點數(正浮點數 + 0)
^(-([1-9]/d*/./d*|0/./d*[1-9]/d*))|0?/.0+|0$  //匹配非正浮點數(負浮點數 + 0)

評注:處理大量數據時有用,具體應用時注意修正

匹配特定字符串:

 程序代碼
^[A-Za-z]+$  //匹配由26個英文字母組成的字符串
^[A-Z]+$  //匹配由26個英文字母的大寫組成的字符串
^[a-z]+$  //匹配由26個英文字母的小寫組成的字符串
^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字符串
^/w+$  //匹配由數字、26個英文字母或者下劃線組成的字符串


在使用 RegularExPRessionValidator 驗證控件時的驗證功能及其驗證表達式介紹如下:

只能輸入數字:
 程序代碼
^[0-9]*$

只能輸入n位的數字:
 程序代碼
^/d{n}$

只能輸入至少n位數字:
 程序代碼
^/d{n,}$

只能輸入m-n位的數字:
 程序代碼
^/d{m,n}$

只能輸入零和非零開頭的數字:
 程序代碼
^(0|[1-9][0-9]*)$

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

只能輸入有1-3位小數的正實數:
 程序代碼
^[0-9]+(.[0-9]{1,3})?$

只能輸入非零的正整數:
 程序代碼
^/+?[1-9][0-9]*$

只能輸入非零的負整數:
 程序代碼
^/-[1-9][0-9]*$

只能輸入長度為3的字符:
 程序代碼
^.{3}$

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

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

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

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

只能輸入由數字、26個英文字母或者下劃線組成的字符串:
 程序代碼
^/w+$

只能輸入漢字:
 程序代碼
^[/u4e00-/u9fa5],{0,}$

驗證用戶密碼:
 程序代碼
^[a-zA-Z]/w{5,17}$

正確格式為:以字母開頭,長度在6-18之間,只能包含字符、數字和下劃線。
驗證是否含有^%&',;=?$/等字符:
 程序代碼
[^%&',;=?$/x22]+

驗證Email地址:
 程序代碼
^/w+[-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)*$

驗證InternetURL:
 程序代碼
^http://([/w-]+/.)+[/w-]+(/[/w-./?%&=]*)?$

驗證電話號碼:
 程序代碼
^(/(/d{3,4}/)|/d{3,4}-)?/d{7,8}$

正確格式為:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX, XXX-XXXXXXXX,XXXXXXX,XXXXXXXX
驗證身份證號(15位或18位數字):
 程序代碼
^/d{15}|/d{}18$

驗證一年的12個月:
 程序代碼
^(0?[1-9]|1[0-2])$

正確格式為:01-09和112
驗證一個月的31天:
 程序代碼
^((0?[1-9])|((1|2)[0-9])|30|31)$

正確格式為:0109和131

-----------------------常用的匹配正則表達式和實例--------------------------------

匹配中文字符的正則表達式:
 程序代碼
[/u4e00-/u9fa5]


匹配雙字節字符(包括漢字在內):
 程序代碼
[^/x00-/xff]


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


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


匹配空行的正則表達式:
 程序代碼
/n[/s| ]*/r


匹配HTML標記的正則表達式:
 程序代碼
/<(.*)>.*<///1>|<(.*) //>/


匹配首尾空格的正則表達式:
 程序代碼
(^/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函數來分解可能更簡單,程序如下:
http://bizhi.VeVb.com/

 程序代碼
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- ./?%&=]*)?


匹配區號、分機號的固定電話正則表達式:
 程序代碼
/^((0/d{2,3})-)(/d{7,8})(-(/d{3,}))?$/


手機號碼前面以1開頭,第二位現在是3或者5,后面是9位數字,則:
 程序代碼
/^1[35]/d{9}$/


更強悍的固定電話號碼正則表達式:
 程序代碼
(^(/d{2,4}[-_-—]?)?/d{3,8}([-_-—]?/d{3,8})?([-_-—]?/d{1,7})?$)|(^0?1[35]/d{9}$)

該表達式可以驗證那些不小心把連接符“-”寫出“-”的或者下劃線“_”的等等。

利用正則表達式去除字串中重復的字符的算法程序:[注:此程序不正確,原因見本貼回復]


 程序代碼
var s="abacabefgeeii"
var s1=s.replace(/(.).*/1/g,"$1")
var re=new RegExp("["+s1+"]","g")
var s2=s.replace(re,"")
alert(s1+s2) //結果為:abcefgi


我原來在CSDN上發貼尋求一個表達式來實現去除重復字符的方法,最終沒有找到,這是我能想到的最簡單的實現方法。思路是使用后向引用取出包括重復的字符,再以重復的字符建立第二個表達式,取到不重復的字符,兩者串連。這個方法對于字符順序有要求的字符串可能不適用。

得用正則表達式從URL地址中提取文件名的javascript程序,如下結果為page1


 程序代碼
s="


用正則表達式限制只能輸入全角字符:
 程序代碼
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,))"

 

 程序代碼
^/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


------------------------------------
利用正則表達式去除字串中重復的字符的算法程序:


 程序代碼
var s="abacabefgeeii"
var s1=s.replace(/(.).*/1/g,"$1")
var re=new RegExp("["+s1+"]","g")
var s2=s.replace(re,"")
alert(s1+s2) //結果為:abcefgi

===============================
如果var s = "abacabefggeeii"
結果就不對了,結果為:abeicfgg
正則表達式的能力有限
----------------------------------------------------------

 程序代碼
Function Extension(url As String) As String
Dim r As New Regex("^(?<proto>/w+)://[^/]+?(?<port>:/d+)?/", _
RegexOptions.Compiled)
Return r.Match(url).Result("${proto}${port}")
End Function


20090701更新:

超強悍的IP地址驗證正則表達式:

 程序代碼
^(0|[1-9]/d?|[0-1]/d{2}|2[0-4]/d|25[0-5]).(0|[1-9]/d?|[0-1]/d{2}|2[0-4]/d|25[0-5]).(0|[1-9]/d?|[0-1]/d{2}|2[0-4]/d|25[0-5]).(0|[1-9]/d?|[0-1]/d{2}|2[0-4]/d|25[0-5])$


支持n級域名判斷的正則表達式:

 程序代碼
^(([^-][a-z0-9A-Z-_]+/.)*)[^-][a-z0-9A-Z-_]+(/.[a-zA-Z]{2,4}){1,2}$


二級域名正則表達式 分析+分割 URL的正則表達式:

 程序代碼
(/w+:////)?([^/.]+)(/.[^/:]+)(:/d*)?([^# ]*)


第一個附加子表達式($1)是用來捕獲該 web 地址的協議部分。該子表達式匹配位于包括一個冒號和兩個正斜杠之前的任何單詞。
第二個附加子表達式($2)捕獲該地址的二級域名地址。該子表達式匹配不包括 '.' 字符的任何字符序列。
第三個附加子表達式($3)捕獲該地址的域名地址。該子表達式匹配不包括 '/' 或 ':' 字符的任何字符序列。
第四個附加子表達式($4)捕獲網站端口號碼,如果指定了該端口號。該子表達式匹配后跟一個冒號的零或多個數字。
第五個附加子表達式($5)捕獲由該 web 地址指定的路徑以及/或者頁面信息。該子表達式匹配一個和多個除'#' 或空格之外的字符。

將該正則表達式應用于http://www.dlstu.cn:80/code/default.asp?id=1056所示的URI 后,子匹配包含如下內容:
RegExp.$0 包含 "RegExp.$1 包含 "http://"
RegExp.$2 包含 "www"
RegExp.$3 包含 ".dlstu.cn"
RegExp.$4 包含 ":80"
RegExp.$5 包含 "/code/default.asp?id=1056"

超強悍的URL網址驗證正則表達式,幾乎可以匹配目前所有的常見網址協議,可以擴充更多以支持其他下載協議等:

 程序代碼
^((https|http|ftp|rtsp|mms)?://)?(([0-9a-z_!~*'().&=+$%-]+: )?[0-9a-zA-Z_!~*'().&=+$%-]+@)?(([0-9]{1,3}/.){3}[0-9]{1,3}|([0-9a-zA-Z_!~*'()-]+/.)*([0-9a-zA-Z][0-9a-zA-Z-]{0,61})?[0-9a-z]/.[a-zA-Z]{2,6})(:[0-9]{1,4})?((/?)|(/[0-9a-zA-Z_!~*'().;?:@&=+$,%#-]+)+/?)$


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲欧美日韩在线 | 一级免费在线视频 | 精品1| 亚洲影视中文字幕 | 国产1区在线观看 | 成年人网站视频免费 | 欧美在线成人影院 | 极品xxxx欧美一区二区 | 做羞羞视频| 国内精品视频饥渴少妇在线播放 | 欧美一级黄色影院 | 美女久久久久 | 欧美人禽 | 黄色网址免费入口 | 在线成人毛片 | 国产成人精品免高潮在线观看 | 视频在线中文字幕 | 免费人成在线播放 | 性片免费看 | 国产九色在线观看 | 日韩视频中文 | 亚洲视频综合网 | 中文字幕免费在线观看视频 | 免费一级欧美 | 神马久久精品综合 | 国产在线观看免费视频软件 | 一区二区三区日韩电影 | 国产精品性夜天天视频 | 欧美高清一级片 | 国产精品99久久久久久宅女 | 国产精品免费视频观看 | 色屁屁xxxxⅹ在线视频 | 亚洲精品com | 色七七网站 | 亚洲字幕av | 欧美中文字幕一区二区 | 欧美黄色一级片在线观看 | 亚洲日色 | 在线播放亚洲视频 | 欧美性猛交xxx乱大交3蜜桃 | 国产又白又嫩又紧又爽18p |