zoukankan      html  css  js  c++  java
  • 正则表达式之整理


    匹配中文字符的正则表达式: [\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函数,我们就可以利用这个表达式来实现,如下:

       1:  String.prototype.trim = function()
       2:  {
       3:  return this.replace(/(^\s*)|(\s*$)/g, "");
       4:  }

    利用正则表达式分解和转换IP地址:
    下面是利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:

       1:  function IP2V(ip)
       2:  {
       3:  re=/(\d+)\.(\d+)\.(\d+)\.(\d+)/g //匹配IP地址的正则表达式
       4:  if(re.test(ip))
       5:  {
       6:  return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1
       7:  }
       8:  else
       9:  {
      10:  throw new Error("Not a valid IP address!")
      11:  }
      12:  }

    不过上面的程序如果不用正则表达式,而直接用split函数来分解可能更简单,程序如下:

       1:  var ip="10.100.20.168"
       2:  ip=ip.split(".")
       3:  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- ./?%&=]*)?
    利用正则表达式去除字串中重复的字符的算法程序:[注:此程序不正确,原因见本贴回复]

       1:  var s="abacabefgeeii"
       2:  var s1=s.replace(/(.).*\1/g,"$1")
       3:  var re=new RegExp("["+s1+"]","g")
       4:  var s2=s.replace(re,"") 
       5:  alert(s1+s2) //结果为:abcefgi

    用正则表达式从URL地址中提取文件名的javascript程序,如下结果为page1

       1:  s="http://www.9499.net/page1.htm"
       2:  s=s.replace(/(.*\/){0,}([^\.]+).*/ig,"$2")
       3:  alert(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,''))"

       1:  补充: 
       2:  ^\d+$  //匹配非负整数(正整数 + 0) 
       3:  ^[0-9]*[1-9][0-9]*$  //匹配正整数 
       4:  ^((-\d+)|(0+))$  //匹配非正整数(负整数 + 0) 
       5:  ^-[0-9]*[1-9][0-9]*$  //匹配负整数 
       6:  ^-?\d+$    //匹配整数 
       7:  ^\d+(\.\d+)?$  //匹配非负浮点数(正浮点数 + 0) 
       8:  ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$  //匹配正浮点数 
       9:  ^((-\d+(\.\d+)?)|(0+(\.0+)?))$  //匹配非正浮点数(负浮点数 + 0) 
      10:  ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$  //匹配负浮点数 
      11:  ^(-?\d+)(\.\d+)?$  //匹配浮点数 
      12:  ^[A-Za-z]+$  //匹配由26个英文字母组成的字符串 
      13:  ^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串 
      14:  ^[a-z]+$  //匹配由26个英文字母的小写组成的字符串 
      15:  ^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串 
      16:  ^\w+$  //匹配由数字、26个英文字母或者下划线组成的字符串 
      17:  ^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$    //匹配email地址 
      18:  ^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$  //匹配url 
      19:   

    另外一些:
       1:  //整数
       2:  "int":"^([+-]?)\\d+$",
       3:  //正整数
       4:  "int+":"^([+]?)\\d+$",                               
       5:  //负整数
       6:  "int-":"^-\\d+$",                                    
       7:  //数字
       8:  "num":"^([+-]?)\\d*\\.?\\d+$",                       
       9:  //正数
      10:  "num+":"^([+]?)\\d*\\.?\\d+$"
      11:  //负数
      12:  "num-":"^-\\d*\\.?\\d+$",                            
      13:  //浮点数
      14:  "float":"^([+-]?)\\d*\\.\\d+$",                      
      15:  //正浮点数
      16:  "float+":"^([+]?)\\d*\\.\\d+$",                      
      17:  //负浮点数
      18:  "float-":"^-\\d*\\.\\d+$",                           
      19:  //邮件
      20:  "email":"^\\w+((-\\w+)|(\\.\\w+))*\\@[A-Za-z0-9]+((\\.|-)[A-Za-z0-9]+)*\\.[A-Za-z0-9]+$",   
      21:  //颜色
      22:  "color":"^#[a-fA-F0-9]{6}"      
      23:  //联接
      24:  "url":"^http[s]?:\\/\\/([\\w-]+\\.)+[\\w-]+([\\w-./?%&=]*)?$",  
      25:  //仅中文
      26:  "chinese":"^[\\u4E00-\\u9FA5\\uF900-\\uFA2D]+$"
      27:  //仅ACSII字符
      28:  "ascii":"^[\\x00-\\xFF]+$"
      29:  //邮编
      30:  "zipcode":"^\\d{6}$"                        
      31:  //手机
      32:  "mobile":"^0{0,1}13[0-9]{9}$"
      33:  //ip地址
      34:  "ip4":"^\(([0-1]\\d{0,2})|(2[0-5]{0,2}))\\.(([0-1]\\d{0,2})|(2[0-5]{0,2}))\\.(([0-1]\\d{0,2})|(2[0-5]{0,2}))\\.(([0-1]\\d{0,2})|(2[0-5]{0,2}))$",    
      35:  //非空
      36:  "notempty":"^\\S+$"
      37:  //图片
      38:  "picture":"(.*)\\.(jpg|bmp|gif|ico|pcx|jpeg|tif|png|raw|tga)$"
      39:  //压缩文件
      40:  "rar":"(.*)\\.(rar|zip|7zip|tgz)$"
      41:  //日期
      42:  "date":"^\\d{2,4}[\\/\\-]?((((0?[13578])|(1[02]))[\\/|\\-]?((0?[1-9]|[0-2][0-9])|(3[01])))|(((0?[469])|(11))[\\/|\\-]?((0?[1-9]|[0-2][0-9])|(30)))|(0?[2][\\/\\-]?(0?[1-9]|[0-2][0-9])))$",                  
      43:  //时间
      44:  "time":"^(20|21|22|23|[01]\\d|\\d)(([:.][0-5]\\d){1,2})$"
  • 相关阅读:
    快速排序和二分查找
    机器学习实战6-线性回归
    机器学习实战5-AdaBoost
    机器学习实战4-SVM
    机器学习实战3-贝叶斯分类
    机器学习实战2-决策树
    win10下caffe安装与mnist测试实验注意点
    机器学习实战1-K均值
    scikit-learn中机器学习模型比较(逻辑回归与KNN)
    结合前向后向算法求隐马尔科夫模型观测序列O的概率
  • 原文地址:https://www.cnblogs.com/qxw0816/p/1565808.html
Copyright © 2011-2022 走看看