一些常用的正则表达式:
- “^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+)?))$”
- “^(-(([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]+$”
- “^[A-Z]+$”
- “^[a-z]+$”
- “^[A-Za-z0-9]+$”
- “^w+$”
- “^[w-]+(.[w-]+)*@[w-]+(.[w-]+)+$”
- “^[a-zA-z]+:
- /^(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})(]?)$”
- “(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])$”
匹配中文字符的正则表达式: [u4e00-u9fa5]
匹配双字节字符(包括汉字在内):[^x00-xff]
匹配空行的正则表达式:n[s| ]*r
匹配HTML标记的正则表达式:/<(.*)>.*</1>|<(.*) />/
匹配首尾空格的正则表达式:(^s*)|(s*$)
匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
匹配网址URL的正则表达式:^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
匹配国内电话号码:(d{3}-|d{4}-)?(d{8}|d{7})?
匹配腾讯QQ号:^[1-9]*[1-9][0-9]*$
javascript中应用
计算字符串的长度(一个双字节字符长度计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
- 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- ./?%&=]*)?
利用正则表达式去除字串中重复的字符的算法程序,代码如下:
- var s=”abacabefgeeii”
- var s1=s.replace(/(.).*1/g,”$1″)
- var re=new RegExp(“["+s1+"]“,”g”)
- var s2=s.replace(re,”")
- alert(s1+s2)
我原来在CSDN上发贴寻求一个表达式来实现去除重复字符的方法,最终没有找到,这是我能想到的最简单的实现方法,思路是使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,两者串连,这个方法对于字符顺序有要求的字符串可能不适用,得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1,代码如下:
- s=”http:
- s=s.replace(/(.*/){0,}([^.]+).*/ig,”$2″)
- alert(s)
php中正则函数和用法
preg_match()和preg_match_all()
preg_quote()
preg_split()
preg_grep()
preg_replace()
函数的具体使用,我们可以通过PHP手册来找到,下面分享一些平时积累的正则表达式.
匹配action属性,以下为引用的内容,代码如下:
- $str = '';
- $match = '';
- preg_match_all('/s+action="(?!http:)(.*?)"s/', $str, $match);
- print_r($match);
在正则中使用回调函数,代码如下:
-
-
-
-
- function callback_replace() {
- $url = 'http://esfang.house.sina.com.cn';
- $str = '';
- $str = preg_replace ( '/(?<=saction=")(?!http:)(.*?)(?="s)/e', 'search($url, \1)', $str );
-
- echo $str;
- }
-
- function search($url, $match){
- return $url . '/' . $match;
- }
|