`
ocw356og
  • 浏览: 24590 次
最近访客 更多访客>>
社区版块
存档分类
最新评论

常用的正则表达式

 
阅读更多

常用的正则表达式
2010年09月09日
  常用表达式:
  "^\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标记的正则表达式:/.*|/
  匹配首尾空格的正则表达式:(^\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]*$
  元字符及其在正则表达式上下文中的行为: 
  \ 将下一个字符标记为一个特殊字符、或一个原义字符、或一个后向引用、或一个八进制转义符。
  ^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的Multiline 属性,^ 也匹配 '\n' 或 '\r' 之后的位置。 
  $ 匹配输入字符串的结束位置。如果设置了 RegExp 对象的Multiline 属性,$ 也匹配 '\n' 或 '\r' 之前的位置。 
  * 匹配前面的子表达式零次或多次。 
  + 匹配前面的子表达式一次或多次。+ 等价于 {1,}。 
  ? 匹配前面的子表达式零次或一次。? 等价于 {0,1}。 
  {n} n 是一个非负整数,匹配确定的n 次。
  {n,} n 是一个非负整数,至少匹配n 次。 
  {n,m} m 和 n 均为非负整数,其中n 表达式,则 n 为后向引用。否则,如果 n 为八进制数字 (0-7),则 n 为一个八进制转义值。 
  \nm 标识一个八进制转义值或一个后向引用。如果 \nm 之前至少有is preceded by at least nm 个获取得子表达式,则 nm 为后向引用。如果 \nm 之前至少有 n 个获取,则 n 为一个后跟文字 m 的后向引用。如果前面的条件都不满足,若 n 和 m 均为八进制数字 (0-7),则 \nm 将匹配八进制转义值 nm。 
  \nml 如果 n 为八进制数字 (0-3),且 m 和 l 均为八进制数字 (0-7),则匹配八进制转义值 nml。 
  \un 匹配 n,其中 n 是一个用四个十六进制数字表示的Unicode字符。
  匹配中文字符的正则表达式: [u4e00-u9fa5]
  匹配双字节字符(包括汉字在内):[^x00-xff]
  匹配空行的正则表达式:n[s| ]*r
  匹配HTML标记的正则表达式:/.*|/ 
  匹配首尾空格的正则表达式:(^s*)|(s*$)
  匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
  匹配网址URL的正则表达式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?
  利用正则表达式限制网页表单里的文本框输入内容:
  用正则表达式限制只能输入中文:onkeyup="value=value.replace(/[^u4E00-u9FA5]/g,'') " ōnbeforepaste="clipboardData.setData('text',clipboa rdData.getData('text').replace(/[^u4E00-u9FA5]/g,'' ))"
  用正则表达式限制只能输入全角字符: ōnkeyup="value=value.replace(/[^uFF00-uFFFF]/g,'')" ōnbeforepaste="clipboardData.setData('text',clipboa rdData.getData('text').replace(/[^uFF00-uFFFF]/g,'' ))"
  用正则表达式限制只能输入数字:onkeyup="value=value.replace(/[^d]/g,'') "onbeforepaste="clipboardData.setData('text',clipb oardData.getData('text').replace(/[^d]/g,''))"
  用正则表达式限制只能输入数字和英文:onkeyup="value=value.replace(/[W]/g,'') "onbeforepaste="clipboardData.setData('text',clipb oardData.getData('text').replace(/[^d]/g,''))" 
  22222222222222222222222222222222222222222222222222 2
  正则表达式是一种通用的标准,大部分计算机语言都支持正则表达式,包括as3,这里转摘出了一些常用的正则表达式语句,大家用到的时候就不用自己写了 
  ^\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 
  匹配中文字符的正则表达式: [\u4e00-\u9fa5] 
  匹配双字节字符(包括汉字在内):[^\x00-\xff] 
  匹配空行的正则表达式:\n[\s| ]*\r 
  匹配HTML标记的正则表达式:/.*|/ 
  匹配首尾空格的正则表达式:(^\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]*$ 
  下表是元字符及其在正则表达式上下文中的行为的一个完整列表: 
  \ 将下一个字符标记为一个特殊字符、或一个原义字符、或一个后向引用、或一个八进制转义符。 
  ^ 匹配输入字符串的开始位置。如果设置了 RegExp 对象的Multiline 属性,^ 也匹配 '\n' 或 '\r' 之后的位置。 
  $ 匹配输入字符串的结束位置。如果设置了 RegExp 对象的Multiline 属性,$ 也匹配 '\n' 或 '\r' 之前的位置。 
  * 匹配前面的子表达式零次或多次。 
  + 匹配前面的子表达式一次或多次。+ 等价于 {1,}。 
  ? 匹配前面的子表达式零次或一次。? 等价于 {0,1}。 
  {n} n 是一个非负整数,匹配确定的n 次。 
  {n,} n 是一个非负整数,至少匹配n 次。 
  {n,m} m 和 n 均为非负整数,其中n 表达式,则 n 为后向引用。否则,如果 n 为八进制数字 (0-7),则 n 为一个八进制转义值。 
  \nm 标识一个八进制转义值或一个后向引用。如果 \nm 之前至少有is preceded by at least nm 个获取得子表达式,则 nm 为后向引用。如果 \nm 之前至少有 n 个获取,则 n 为一个后跟文字 m 的后向引用。如果前面的条件都不满足,若 n 和 m 均为八进制数字 (0-7),则 \nm 将匹配八进制转义值 nm。 
  \nml 如果 n 为八进制数字 (0-3),且 m 和 l 均为八进制数字 (0-7),则匹配八
  本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/liehuo123/archive/2008/07/30/ 2742577.aspx
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics