WIKI使用導(dǎo)航
站長百科導(dǎo)航
站長專題
- 網(wǎng)站推廣
- 網(wǎng)站程序
- 網(wǎng)站賺錢
- 虛擬主機(jī)
- cPanel
- 網(wǎng)址導(dǎo)航專題
- 云計算
- 微博營銷
- 虛擬主機(jī)管理系統(tǒng)
- 開放平臺
- WIKI程序與應(yīng)用
- 美國十大主機(jī)
Php-正則表達(dá)式應(yīng)用
導(dǎo)航: 上一頁 | ASP | PHP | JSP | HTML | CSS | XHTML | aJAX | Ruby | JAVA | XML | Python | ColdFusion
目前,正則表達(dá)式已經(jīng)在很多軟件中得到廣泛的應(yīng)用,包括*nix(Linux、Unix等)、HP等操作系統(tǒng),PHP、C#、Java等開發(fā)語言,以及很多的應(yīng)用軟件中,都可以看到正則表達(dá)式的影子。
PHP一些常用的正則表達(dá)式
匹配中文字符的javascript:;" target="_self">正則表達(dá)式: [\u4e00-\u9fa5]
匹配雙字節(jié)字符(包括漢字在內(nèi)): [^\x00-\xff]
應(yīng)用:計算字符串的長度(一個雙字節(jié)字符長度計2,ASCII字符計1)
String.prototype.len=function(){return this.replace([^\x00-\xff]/g,"aa").length;}
匹配空行的正則表達(dá)式: \n[\s| ]*\r
匹配HTML標(biāo)記的正則表達(dá)式: /<(.*)>.*<\/>|<(.*) \/>/
匹配首尾空格的正則表達(dá)式: (^\s*)|(\s*$)
應(yīng)用:javascript中沒有像vbscript那樣的trim函數(shù),我們就可以利用這個表達(dá)式來實現(xiàn),如下:
String.prototype.trim = function() {
return this.replace(/(^\s*)|(\s*$)/g, "");
}
利用正則表達(dá)式分解和轉(zhuǎn)換IP地址:
下面是利用正則表達(dá)式匹配IP地址,并將IP地址轉(zhuǎn)換成對應(yīng)數(shù)值的javascript程序:
function IP2V(ip) {
re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //匹配IP地址的正則表達(dá)式
if(re.test(ip)) {
return RegExp.*Math.pow(255,3))+RegExp.*Math.pow(255,2))+RegExp.*255+RegExp.*1
}
else {
throw new Error("Not a valid IP address!")
}
}
不過上面的程序如果不用正則表達(dá)式,而直接用split函數(shù)來分解可能更簡單,程序如下:
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地址的正則表達(dá)式: \w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*
匹配網(wǎng)址URL的正則表達(dá)式: http://([\w-]+\.)+[\w-]+(/[\w- ./?%&=]*)?
利用正則表達(dá)式去除字串中重復(fù)的字符的算法程序:
var s="abacabefgeeii"
var s1=s.replace(/(.).*/g,"")
var re=new RegExp("["+s1+"]","g")
var s2=s.replace(re,"")
alert(s1+s2) //結(jié)果為:abcefgi
用正則表達(dá)式從URL地址中提取文件名的javascript程序,如下結(jié)果為page1
s="
s=s.replace(/(.*\/)([^\.]+).*/ig,"")
alert(s)
利用正則表達(dá)式限制網(wǎng)頁表單里的文本框輸入內(nèi)容:
用正則表達(dá)式限制只能輸入中文:
用正則表達(dá)式限制只能輸入全角字符:
用正則表達(dá)式限制只能輸入數(shù)字:
用正則表達(dá)式限制只能輸入數(shù)字和英文:
onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,))
MySql正則表達(dá)式的描述
正則表達(dá)式(regex)是定義復(fù)雜查詢的一個強(qiáng)有力的工具。
這里是一個簡單的資料,它忽略了一些詳細(xì)的信息。
正則表達(dá)式定義了一個字符串的規(guī)則。最簡單的正則表達(dá)式不包含任何保留字。例如,正則表達(dá)式hello只和字符串“hello”匹配。
一般的正則表達(dá)式使用了某些特殊的結(jié)構(gòu),所以它能匹配更多的字符串。例如,正則表達(dá)式hello|word既能匹配字符串“hello”也能匹配字符串 “word”。舉一個更復(fù)雜一點的例子,正則表達(dá)式b[an]*s可以匹配字符串“bananas”、“baaaaas” 、“bs”以及其他任何以b開頭以s結(jié)尾的字符串,中間可以包括任意個a和任意個n的組合。
一個正則表達(dá)式中的可以使用以下保留字
^
所匹配的字符串以后面的字符串開頭
mysql> select "fonfo" regexp "^fo$"; -> 0(表示不匹配)
mysql> select "fofo" regexp "^fo"; -> 1(表示匹配)
$
所匹配的字符串以前面的字符串結(jié)尾
mysql> select "fono" regexp "^fono$"; -> 1(表示匹配)
mysql> select "fono" regexp "^fo$"; -> 0(表示不匹配)
.
匹配任何字符(包括新行)
mysql> select "fofo" regexp "^f.*"; -> 1(表示匹配)
mysql> select "fonfo" regexp "^f.*"; -> 1(表示匹配)
a*
匹配任意多個a(包括空串)
mysql> select "ban" regexp "^ba*n"; -> 1(表示匹配)
mysql> select "baaan" regexp "^ba*n"; -> 1(表示匹配)
mysql> select "bn" regexp "^ba*n"; -> 1(表示匹配)
a+
匹配任意多個a(不包括空串)
mysql> select "ban" regexp "^ba+n"; -> 1(表示匹配)
mysql> select "bn" regexp "^ba+n"; -> 0(表示不匹配)
a?
匹配一個或零個a
mysql> select "bn" regexp "^ba?n"; -> 1(表示匹配)
mysql> select "ban" regexp "^ba?n"; -> 1(表示匹配)
mysql> select "baan" regexp "^ba?n"; -> 0(表示不匹配)
de|abc
匹配de或abc
mysql> select "pi" regexp "pi|apa"; -> 1(表示匹配)
mysql> select "axe" regexp "pi|apa"; -> 0(表示不匹配)
mysql> select "apa" regexp "pi|apa"; -> 1(表示匹配)
mysql> select "apa" regexp "^(pi|apa)$"; -> 1(表示匹配)
mysql> select "pi" regexp "^(pi|apa)$"; -> 1(表示匹配)
mysql> select "pix" regexp "^(pi|apa)$"; -> 0(表示不匹配)
(abc)*
匹配任意多個abc(包括空串)
mysql> select "pi" regexp "^(pi)*$"; -> 1(表示匹配)
mysql> select "pip" regexp "^(pi)*$"; -> 0(表示不匹配)
mysql> select "pipi" regexp "^(pi)*$"; -> 1(表示匹配)
{1}
{2,3}
這是一個更全面的方法,它可以實現(xiàn)前面好幾種保留字的功能
a*
可以寫成a{0,}
a+
可以寫成a{1,}
a?
可以寫成a{0,1}
在{}內(nèi)只有一個整型參數(shù)i,表示字符只能出現(xiàn)i次;在{}內(nèi)有一個整型參數(shù)i,后面跟一個“,”,表示字符可以出現(xiàn)i次或i次以上;在{}內(nèi)只有一個整型參數(shù)i,后面跟一個“,”,再跟一個整型參數(shù)j,表示字符只能出現(xiàn)i次以上,j次以下(包括i次和j次)。其中的整型參數(shù)必須大于等于0,小于等于 re_dup_max(默認(rèn)是255)。如果有兩個參數(shù),第二個必須大于等于第一個
[a-dx]
匹配“a”、“b”、“c”、“d”或“x”
[^a-dx]
匹配除“a”、“b”、“c”、“d”、“x”以外的任何字符?!癧”、“]”必須成對使用
mysql> select "axbc" regexp "[a-dxyz]"; -> 1(表示匹配)
mysql> select "axbc" regexp "^[a-dxyz]$"; -> 0(表示不匹配)
mysql> select "axbc" regexp "^[a-dxyz]+$"; -> 1(表示匹配)
mysql> select "axbc" regexp "^[^a-dxyz]+$"; -> 0(表示不匹配)
mysql> select "gheis" regexp "^[^a-dxyz]+$"; -> 1(表示匹配)
mysql> select "gheisa" regexp "^[^a-dxyz]+$"; -> 0(表示不匹配)