夢幻之旅

          DEBUG - 天道酬勤

             :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
            671 隨筆 :: 6 文章 :: 256 評論 :: 0 Trackbacks

          正則表達(dá)式用于字符串處理,表單驗證等場合,實用高效,但用到時總是不太把握,以致往往要上網(wǎng)查一番。我將一些常用的表達(dá)式收藏在這里,作備忘之用。本貼隨時會更新。

          匹配中文字符的正則表達(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á)式:/<(.*)>.*<\/\1>|<(.*) \/>/

          匹配首尾空格的正則表達(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.$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!")
          }
          }

          不過上面的程序如果不用正則表達(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ù)的字符的算法程序:[注:此程序不正確,原因見本貼回復(fù)]

          var s="abacabefgeeii"
          var s1=s.replace(/(.).*\1/g,"$1")
          var re=new RegExp("["+s1+"]","g")
          var s2=s.replace(re,"")
          alert(s1+s2)  //結(jié)果為:abcefgi

          我原來在CSDN上發(fā)貼尋求一個表達(dá)式來實現(xiàn)去除重復(fù)字符的方法,最終沒有找到,這是我能想到的最簡單的實現(xiàn)方法。思路是使用后向引用取出包括重復(fù)的字符,再以重復(fù)的字符建立第二個表達(dá)式,取到不重復(fù)的字符,兩者串連。這個方法對于字符順序有要求的字符串可能不適用。

          得用正則表達(dá)式從URL地址中提取文件名的javascript程序,如下結(jié)果為page1

          s="http://www.9499.net/page1.htm"
          s=s.replace(/(.*\/){0,}([^\.]+).*/ig,"$2")
          alert(s)

          利用正則表達(dá)式限制網(wǎng)頁表單里的文本框輸入內(nèi)容:

          用正則表達(dá)式限制只能輸入中文:onkeyup="value=value.replace(/[^\u4E00-\u9FA5]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\u4E00-\u9FA5]/g,''))"

          用正則表達(dá)式限制只能輸入全角字符: onkeyup="value=value.replace(/[^\uFF00-\uFFFF]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\uFF00-\uFFFF]/g,''))"

          用正則表達(dá)式限制只能輸入數(shù)字:onkeyup="value=value.replace(/[^\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"

          用正則表達(dá)式限制只能輸入數(shù)字和英文:onkeyup="value=value.replace(/[\W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))"

          正則表達(dá)式,相關(guān)鏈接
          http://blog.csdn.net/laily/category/19548.aspx
          http://blog.csdn.net/laily/archive/2004/06/30/30525.aspx 微軟的正則表達(dá)式教程(五):選擇/編組和后向引用

          http://blog.csdn.net/laily/archive/2004/06/30/30522.aspx 微軟的正則表達(dá)式教程(四):限定符和定位符

          http://blog.csdn.net/laily/archive/2004/06/30/30517.aspx 微軟的正則表達(dá)式教程(三):字符匹配

          http://blog.csdn.net/laily/archive/2004/06/30/30514.aspx 微軟的正則表達(dá)式教程(二):正則表達(dá)式語法和優(yōu)先權(quán)順序

          http://blog.csdn.net/laily/archive/2004/06/30/30511.aspx 微軟的正則表達(dá)式教程(一):正則表達(dá)式簡介

          http://blog.csdn.net/laily/archive/2004/06/30/30360.aspx 小程序大作為:高級.找/替換、正則表達(dá)式練習(xí)器、Javascript腳本程序調(diào)試器

          http://blog.csdn.net/laily/archive/2004/06/24/25872.aspx 經(jīng)典正則表達(dá)式

          正則表達(dá)式,正規(guī)表達(dá)式,正則表達(dá)式匹配,正則表達(dá)式語法,模式匹配,正規(guī)表達(dá)式匹配 javascript正則表達(dá)式 ASP正則表達(dá)式 ASP.NET正則表達(dá)式 C#正則表達(dá)式 JSP正則表達(dá)式 PHP正則表達(dá)式 VB.NET正則表達(dá)式 VBSCript正則表達(dá)式編程 delphi正則表達(dá)式 jscript

          補(bǔ)充:
          ^\d+$  //匹配非負(fù)整數(shù)(正整數(shù) + 0)
          ^[0-9]*[1-9][0-9]*$  //匹配正整數(shù)
          ^((-\d+)|(0+))$  //匹配非正整數(shù)(負(fù)整數(shù) + 0)
          ^-[0-9]*[1-9][0-9]*$  //匹配負(fù)整數(shù)
          ^-?\d+$    //匹配整數(shù)
          ^\d+(\.\d+)?$  //匹配非負(fù)浮點數(shù)(正浮點數(shù) + 0)
          ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$  //匹配正浮點數(shù)
          ^((-\d+(\.\d+)?)|(0+(\.0+)?))$  //匹配非正浮點數(shù)(負(fù)浮點數(shù) + 0)
          ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$  //匹配負(fù)浮點數(shù)
          ^(-?\d+)(\.\d+)?$  //匹配浮點數(shù)
          ^[A-Za-z]+$  //匹配由26個英文字母組成的字符串
          ^[A-Z]+$  //匹配由26個英文字母的大寫組成的字符串
          ^[a-z]+$  //匹配由26個英文字母的小寫組成的字符串
          ^[A-Za-z0-9]+$  //匹配由數(shù)字和26個英文字母組成的字符串
          ^\w+$  //匹配由數(shù)字、26個英文字母或者下劃線組成的字符串
          ^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$    //匹配email地址
          ^[a-zA-z]+://匹配(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$  //匹配url

          利用正則表達(dá)式去除字串中重復(fù)的字符的算法程序:

          var s="abacabefgeeii"
          var s1=s.replace(/(.).*\1/g,"$1")
          var re=new RegExp("["+s1+"]","g")
          var s2=s.replace(re,"")
          alert(s1+s2) //結(jié)果為:abcefgi
          ===============================
          如果var s = "abacabefggeeii"
          結(jié)果就不對了,結(jié)果為:abeicfgg
          正則表達(dá)式的能力有限

          1.確認(rèn)有效電子郵件格式
          下面的代碼示例使用靜態(tài) Regex.IsMatch 方法驗證一個字符串是否為有效電子郵件格式。如果字符串包含一個有效的電子郵件地址,則 IsValidEmail 方法返回 true,否則返回 false,但不采取其他任何操作。您可以使用 IsValidEmail,在應(yīng)用程序?qū)⒌刂反鎯υ跀?shù)據(jù)庫中或顯示在 ASP.NET 頁中之前,篩選出包含無效字符的電子郵件地址。

          [Visual Basic]
          Function IsValidEmail(strIn As String) As Boolean
          ' Return true if strIn is in valid e-mail format.
          Return Regex.IsMatch(strIn, ("^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$")
          End Function
          [C#]
          bool IsValidEmail(string strIn)
          {
          // Return true if strIn is in valid e-mail format.
          return Regex.IsMatch(strIn, @"^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$");
          }


          2.清理輸入字符串
          下面的代碼示例使用靜態(tài) Regex.Replace 方法從字符串中抽出無效字符。您可以使

           

          1.確認(rèn)有效電子郵件格式 下面的代碼示例使用靜態(tài) Regex.IsMatch 方法驗證一個字符串是否為有效電子郵件格式。如果字符串包含一個有效的電子郵件地址,則 IsValidEmail 方法返回 true,否則返回 false,但不采取其他任何操作。您可以使用 IsValidEmail,在應(yīng)用程序?qū)⒌刂反鎯υ跀?shù)據(jù)庫中或顯示在 ASP.NET 頁中之前,篩選出包含無效字符的電子郵件地址。 [Visual Basic] Function IsValidEmail(strIn As String) As Boolean ' Return true if strIn is in valid e-mail format. Return Regex.IsMatch(strIn, ("^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$") End Function [C#] bool IsValidEmail(string strIn) { // Return true if strIn is in valid e-mail format. return Regex.IsMatch(strIn, @"^([\w-\.]+)@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.)|(([\w-]+\.)+))([a-zA-Z]{2,4}|[0-9]{1,3})(\]?)$"); } 2.清理輸入字符串 下面的代碼示例使用靜態(tài) Regex.Replace 方法從字符串中抽出無效字符。
          posted on 2008-01-02 16:19 HUIKK 閱讀(170) 評論(0)  編輯  收藏 所屬分類: Java
          主站蜘蛛池模板: 陇川县| 中江县| 克拉玛依市| 牙克石市| 辰溪县| 奉新县| 石渠县| 阜阳市| 麻栗坡县| 集贤县| 雅江县| 西藏| 齐齐哈尔市| 德格县| 辽源市| 龙口市| 化州市| 嫩江县| 大足县| 夹江县| 张家界市| 子长县| 绥宁县| 崇阳县| 犍为县| 涪陵区| 建阳市| 翼城县| 陇川县| 南陵县| 手游| 大埔县| 绥棱县| 江川县| 加查县| 龙岩市| 中山市| 侯马市| 平和县| 会泽县| 贡嘎县|