常用的正则表达式(php asp javascript)学习手册
一些常用的正则表达式:
- “^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地址
匹配中文字符的正则表达式: [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),代码如下:
匹配空行的正则表达式: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函数来分解可能更简单,程序如下,代码如下:
- 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) //结果为:abcefgi
我原来在CSDN上发贴寻求一个表达式来实现去除重复字符的方法,最终没有找到,这是我能想到的最简单的实现方法,思路是使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,两者串连,这个方法对于字符顺序有要求的字符串可能不适用,得用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1,代码如下:
- s=”http://www.phpfensi.com/nokia/5230/”
- 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);
在正则中使用回调函数,代码如下:
- /**
- * replace some string by callback function
- *
- */
- 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;
- }