1. 程式人生 > >SAP ABAP常用正則表示式大全

SAP ABAP常用正則表示式大全

特殊表示式 :

  1.貨幣格式: '123123211312.333333'.replace(/(?=(?!^)(?:\d{3})+(?:\.|$))(\d{3}(\.\d+$)?)/g, ',$1') //輸出 123,123,211,312.333333  ps:TCL 大牛推薦

匹配中文字元的正則表示式: [u4e00-u9fa5]      評註:匹配中文還真是個頭疼的事,有了這個表示式就好辦了    匹配雙位元組字元(包括漢字在內):[^x00-xff]    評註:可以用來計算字串的長度(一個雙位元組字元長度計2,ASCII字元計1)    匹配空白行的正則表示式:ns*r    評註:可以用來刪除空白行    匹配HTML標記的正則表示式:<(S*?)[^>]*>.*?|<.*? />    評註:網上流傳的版本太糟糕,上面這個也僅僅能匹配部分,對於複雜的巢狀標記依舊無能為力    匹配首尾空白字元的正則表示式:^s*|s*$    評註:可以用來刪除行首行尾的空白字元(包括空格、製表符、換頁符等等),非常有用的表示式    匹配Email地址的正則表示式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*    評註:表單驗證時很實用    匹配網址URL的正則表示式:[a-zA-z]+://[^s]*    評註:網上流傳的版本功能很有限,上面這個基本可以滿足需求    匹配帳號是否合法(字母開頭,允許5-16位元組,允許字母數字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$    評註:表單驗證時很實用    匹配國內電話號碼:d{3}-d{8}|d{4}-d{7}    評註:匹配形式如 0511-4405222 或 021-87888822    匹配騰訊QQ號:[1-9][0-9]{4,}    評註:騰訊QQ號從10000開始    匹配中國郵政編碼:[1-9]d{5}(?!d)    評註:中國郵政編碼為6位數字    匹配身份證:d{15}|d{18}    評註:中國的身份證為15位或18位    匹配ip地址:d+.d+.d+.d+    評註:提取ip地址時有用    匹配特定數字:    ^[1-9]d*$    //匹配正整數    ^-[1-9]d*$   //匹配負整數    ^-?[1-9]d*$   //匹配整數    ^[1-9]d*|0$  //匹配非負整數(正整數 + 0)    ^-[1-9]d*|0$   //匹配非正整數(負整數 + 0)    ^[1-9]d*.d*|0.d*[1-9]d*$   //匹配正浮點數    ^-([1-9]d*.d*|0.d*[1-9]d*)$  //匹配負浮點數    ^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$  //匹配浮點數    ^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$   //匹配非負浮點數(正浮點數 + 0)    ^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$  //匹配非正浮點數(負浮點數 + 0)    評註:處理大量資料時有用,具體應用時注意修正    匹配特定字串:    ^[A-Za-z]+$  //匹配由26個英文字母組成的字串    ^[A-Z]+$  //匹配由26個英文字母的大寫組成的字串    ^[a-z]+$  //匹配由26個英文字母的小寫組成的字串    ^[A-Za-z0-9]+$  //匹配由數字和26個英文字母組成的字串    ^w+$  //匹配由數字、26個英文字母或者下劃線組成的字串    在使用RegularExpressionValidator驗證控制元件時的驗證功能及其驗證表示式介紹如下:    只能輸入數字:“^[0-9]*$”    只能輸入n位的數字:“^d{n}$”    只能輸入至少n位數字:“^d{n,}$”    只能輸入m-n位的數字:“^d{m,n}$”    只能輸入零和非零開頭的數字:“^(0|[1-9][0-9]*)$”    只能輸入有兩位小數的正實數:“^[0-9]+(.[0-9]{2})?$”    只能輸入有1-3位小數的正實數:“^[0-9]+(.[0-9]{1,3})?$”    只能輸入非零的正整數:“^+?[1-9][0-9]*$”    只能輸入非零的負整數:“^-[1-9][0-9]*$”    只能輸入長度為3的字元:“^.{3}$”    只能輸入由26個英文字母組成的字串:“^[A-Za-z]+$”    只能輸入由26個大寫英文字母組成的字串:“^[A-Z]+$”    只能輸入由26個小寫英文字母組成的字串:“^[a-z]+$”    只能輸入由數字和26個英文字母組成的字串:“^[A-Za-z0-9]+$”    只能輸入由數字、26個英文字母或者下劃線組成的字串:“^w+$”    驗證使用者密碼:“^[a-zA-Z]w{5,17}$”正確格式為:以字母開頭,長度在6-18之間,    只能包含字元、數字和下劃線。    驗證是否含有^%&'',;=?$"等字元:“[^%&'',;=?$x22]+”    只能輸入漢字:“^[u4e00-u9fa5],{0,}$”    驗證Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$”    驗證InternetURL:“^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$”    驗證電話號碼:“^((d{3,4})|d{3,4}-)?d{7,8}$”    正確格式為:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”,    “XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。    驗證身份證號(15位或18位數字):“^d{15}|d{}18$”    驗證一年的12個月:“^(0?[1-9]|1[0-2])$”正確格式為:“01”-“09”和“1”“12”    驗證一個月的31天:“^((0?[1-9])|((1|2)[0-9])|30|31)$”    正確格式為:“01”“09”和“1”“31”。    匹配中文字元的正則表示式: [u4e00-u9fa5]    匹配雙位元組字元(包括漢字在內):[^x00-xff]    匹配空行的正則表示式:n[s| ]*r    匹配HTML標記的正則表示式:/<(.*)>.*|<(.*) />/    匹配首尾空格的正則表示式:(^s*)|(s*$)    匹配Email地址的正則表示式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*    匹配網址URL的正則表示式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?    (1)應用:計算字串的長度(一個雙位元組字元長度計2,ASCII字元計1)    String.prototype.len=function(){return this.replace([^x00-xff]/g,"aa").length;}   (2)應用:javascript中沒有像vbscript那樣的trim函式,我們就可以利用這個表示式來實現    String.prototype.trim = function()    {    return this.replace(/(^s*)|(s*$)/g, "");    }    (3)應用:利用正則表示式分解和轉換IP地址    function IP2V(ip) //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!")    }    }    (4)應用:從URL地址中提取檔名的javascript程式    s="http://www.9499.net/page1.htm";    s=s.replace(/(.*/){0,}([^.]+).*/ig,"$2") ;//Page1.htm    (5)應用:利用正則表示式限制網頁表單裡的文字框輸入內容    用正則表示式限制只能輸入中文: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,'' 以下轉自網路部落格:

另外,REPLACE也支援REGEX關鍵字。 最後:只能是ECC6或者更高版本才可以(ABAP supports POSIX regular expressions as of Release 7.00)

REPORT z_test.

DATA: str TYPE string , result_tab TYPE match_result_tab , wa LIKE LINE OF result_tab.

*找出STRING裡面的雙位元組字元 str = 'abc我啊adfsf們'. FIND ALL OCCURRENCES OF REGEX '[^x00-xff]*' IN str RESULTS result_tab. LOOP AT result_tab INTO wa. WRITE / str+wa-offset(wa-length). ENDLOOP.

*找出STRING裡面的單位元組字元 str = 'abc我啊adfsf們'. FIND ALL OCCURRENCES OF REGEX '[x00-xff]*' IN str RESULTS result_tab. WRITE / '-----'. LOOP AT result_tab INTO wa. WRITE / str+wa-offset(wa-length). ENDLOOP.

*找出STRING裡面的IP地址 str = 'IP1:172.16.32.12 IP2:192.168.1.1 '. FIND ALL OCCURRENCES OF REGEX 'd+.d+.d+.d+' IN str RESULTS result_tab. WRITE / '-----'. LOOP AT result_tab INTO wa. WRITE / str+wa-offset(wa-length). ENDLOOP.

*找出STRING裡面的***-********格式的電話號碼 str = 'IP1:172.16.32.12 021-12345678 '. FIND ALL OCCURRENCES OF REGEX 'd{3}-d{8}|d{4}-d{7}' IN str RESULTS result_tab. WRITE / '-----'. LOOP AT result_tab INTO wa. WRITE / str+wa-offset(wa-length). ENDLOOP.

*找出STRING裡面的15/18位身份證號碼 str = 'IP1:172.16.32.12 3722198003041234 '. FIND ALL OCCURRENCES OF REGEX 'd{15}|d{18}' IN str RESULTS result_tab. WRITE / '-----'. LOOP AT result_tab INTO wa. WRITE / str+wa-offset(wa-length). ENDLOOP.

***使用CLASS的例子:

REPORT z_barry_test.

PARAMETERS: p_input TYPE string DEFAULT 'IP1:172.16.32.12 IP2:192.168.1.1 ' OBLIGATORY.

DATA: regex TYPE REF TO cl_abap_regex, matcher TYPE REF TO cl_abap_matcher, match TYPE c .

DATA: result_tab TYPE match_result_tab , wa LIKE LINE OF result_tab.

CREATE OBJECT regex EXPORTING pattern = 'd+.d+.d+.d+' ignore_case = 'X'.

TRY. CALL METHOD regex->create_matcher EXPORTING text = p_input * table = RECEIVING matcher = matcher . CATCH cx_sy_matcher . ENDTRY.

TRY. CALL METHOD matcher->match "是否完全匹配 RECEIVING success = match. CATCH cx_sy_matcher . ENDTRY.

CALL METHOD matcher->find_all RECEIVING matches = result_tab. LOOP AT result_tab INTO wa. WRITE / p_input+wa-offset(wa-length). ENDLOOP.

***SAP給的判斷Email地址的例子***

PARAMETERS email TYPE c LENGTH 30 LOWER CASE DEFAULT '[email protected]'.

DATA matcher TYPE REF TO cl_abap_matcher. matcher = cl_abap_matcher=>create( pattern = 'w+(.w+)*@(w+.)+(w{2,4})' ignore_case = 'X' text = email ). IF matcher->match( ) IS INITIAL. MESSAGE 'Wrong Format' TYPE 'I'. ELSE. MESSAGE 'Format OK' TYPE 'I'. ENDIF.