2006年11月2日

          近來需要寫一些JSF的Validator,于是想起來用正則表達式,果然是書到用時方恨少,居然除了[a-z]?,\d 這些以外什么都想不起來了。
          上網找尋了一些資料如下:

          ?匹配中文字符的正則表達式: [\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函數,我們就可以利用這個表達式來實現,如下:

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

          利用正則表達式限制網頁表單里的文本框輸入內容:

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

          用正則表達式限制只能輸入全角字符: 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,''))"


          同時找到一個可以測試正則表達式的正確性的小軟件,很不錯,居然可以語法高亮。不過說實話正則表達式寫出來亂七八糟的,就算有分色顯示看起來也好不到哪里去。。。。。。

          MTracer 下載
          posted @ 2006-11-16 15:46 展昭 閱讀(826) | 評論 (1)編輯 收藏
           

          前提是該范型中包含的對象Object已經實現了Collections.sort()要求的接口:
          public int compareTo(Object o)

          這個compareTo的方法應當直接的表現出你想要以Object的哪個字段進行排序
          我們可以這樣寫:
          public int compareTo(Object o) {
          ??????? DbPoJo po = null;
          ??????? if(o instanceof DbPoJo)
          ??????????? po = (DbPoJo)o;
          ??????? return po.getId().compareTo(this.getId());
          }
          假設我們的List中包含的每個元素都是 DbPoJo 這個對象,在這里需要先將Object強制轉換為DbPoJo
          然后就可以利用String的compareTo()方法來進行返回

          最后,對我們的List :List<DbPoJo> returnList = new ArrayList<DbPoJo>();
          通過調用Collections的靜態方法 sort() 進行排序:
          Collections.sort(returnList);

          通過上例,可以看出一個類一旦實現Comparable接口,那么它就可以跟很多依賴于該接口的集合進行協作。
          用《Effective JAVA 》的話來說:你可以以很小的努力,來獲得非常強大的功能

          posted @ 2006-11-02 12:16 展昭 閱讀(2040) | 評論 (3)編輯 收藏
           
          主站蜘蛛池模板: 南漳县| 蚌埠市| 紫阳县| 广平县| 汶上县| 衡东县| 个旧市| 齐河县| 长沙市| 巴林右旗| 静安区| 子长县| 苍山县| 文水县| 麻城市| 阿拉善右旗| 喀什市| 全椒县| 阿克| 仪征市| 武冈市| 台中市| 拜泉县| 台江县| 朝阳县| 南陵县| 漳浦县| 祁东县| 贵德县| 天祝| 吐鲁番市| 沅江市| 五华县| 新野县| 汉寿县| 保德县| 曲水县| 遵义市| 商河县| 房产| 蒲江县|