SAP ABAP常用正则表达式大全
特殊表達(dá)式 :
1.貨幣格式: '123123211312.333333'.replace(/(?=(?!^)(?:\d{3})+(?:\.|$))(\d{3}(\.\d+$)?)/g, ',$1') //輸出 123,123,211,312.333333? ps:TCL 大牛推薦
匹配中文字符的正則表達(dá)式: [u4e00-u9fa5]???
評注:匹配中文還真是個(gè)頭疼的事,有了這個(gè)表達(dá)式就好辦了?
匹配雙字節(jié)字符(包括漢字在內(nèi)):[^x00-xff]?
評注:可以用來計(jì)算字符串的長度(一個(gè)雙字節(jié)字符長度計(jì)2,ASCII字符計(jì)1)?
匹配空白行的正則表達(dá)式:ns*r?
評注:可以用來刪除空白行?
匹配HTML標(biāo)記的正則表達(dá)式:<(S*?)[^>]*>.*?|<.*? />?
評注:網(wǎng)上流傳的版本太糟糕,上面這個(gè)也僅僅能匹配部分,對于復(fù)雜的嵌套標(biāo)記依舊無能為力?
匹配首尾空白字符的正則表達(dá)式:^s*|s*$?
評注:可以用來刪除行首行尾的空白字符(包括空格、制表符、換頁符等等),非常有用的表達(dá)式?
匹配Email地址的正則表達(dá)式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*?
評注:表單驗(yàn)證時(shí)很實(shí)用?
匹配網(wǎng)址URL的正則表達(dá)式:[a-zA-z]+://[^s]*?
評注:網(wǎng)上流傳的版本功能很有限,上面這個(gè)基本可以滿足需求?
匹配帳號是否合法(字母開頭,允許5-16字節(jié),允許字母數(shù)字下劃線):^[a-zA-Z][a-zA-Z0-9_]{4,15}$?
評注:表單驗(yàn)證時(shí)很實(shí)用?
匹配國內(nèi)電話號碼: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位數(shù)字?
匹配身份證:d{15}|d{18}?
評注:中國的身份證為15位或18位?
匹配ip地址:d+.d+.d+.d+?
評注:提取ip地址時(shí)有用?
匹配特定數(shù)字:?
^[1-9]d*$ //匹配正整數(shù)?
^-[1-9]d*$ //匹配負(fù)整數(shù)?
^-?[1-9]d*$ //匹配整數(shù)?
^[1-9]d*|0$ //匹配非負(fù)整數(shù)(正整數(shù) + 0)?
^-[1-9]d*|0$ //匹配非正整數(shù)(負(fù)整數(shù) + 0)?
^[1-9]d*.d*|0.d*[1-9]d*$ //匹配正浮點(diǎn)數(shù)?
^-([1-9]d*.d*|0.d*[1-9]d*)$ //匹配負(fù)浮點(diǎn)數(shù)?
^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$ //匹配浮點(diǎn)數(shù)?
^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$ //匹配非負(fù)浮點(diǎn)數(shù)(正浮點(diǎn)數(shù) + 0)?
^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$ //匹配非正浮點(diǎn)數(shù)(負(fù)浮點(diǎn)數(shù) + 0)?
評注:處理大量數(shù)據(jù)時(shí)有用,具體應(yīng)用時(shí)注意修正?
匹配特定字符串:?
^[A-Za-z]+$ //匹配由26個(gè)英文字母組成的字符串?
^[A-Z]+$ //匹配由26個(gè)英文字母的大寫組成的字符串?
^[a-z]+$ //匹配由26個(gè)英文字母的小寫組成的字符串?
^[A-Za-z0-9]+$ //匹配由數(shù)字和26個(gè)英文字母組成的字符串?
^w+$ //匹配由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串?
在使用RegularExpressionValidator驗(yàn)證控件時(shí)的驗(yàn)證功能及其驗(yàn)證表達(dá)式介紹如下:?
只能輸入數(shù)字:“^[0-9]*$”?
只能輸入n位的數(shù)字:“^d{n}$”?
只能輸入至少n位數(shù)字:“^d{n,}$”?
只能輸入m-n位的數(shù)字:“^d{m,n}$”?
只能輸入零和非零開頭的數(shù)字:“^(0|[1-9][0-9]*)$”?
只能輸入有兩位小數(shù)的正實(shí)數(shù):“^[0-9]+(.[0-9]{2})?$”?
只能輸入有1-3位小數(shù)的正實(shí)數(shù):“^[0-9]+(.[0-9]{1,3})?$”?
只能輸入非零的正整數(shù):“^+?[1-9][0-9]*$”?
只能輸入非零的負(fù)整數(shù):“^-[1-9][0-9]*$”?
只能輸入長度為3的字符:“^.{3}$”?
只能輸入由26個(gè)英文字母組成的字符串:“^[A-Za-z]+$”?
只能輸入由26個(gè)大寫英文字母組成的字符串:“^[A-Z]+$”?
只能輸入由26個(gè)小寫英文字母組成的字符串:“^[a-z]+$”?
只能輸入由數(shù)字和26個(gè)英文字母組成的字符串:“^[A-Za-z0-9]+$”?
只能輸入由數(shù)字、26個(gè)英文字母或者下劃線組成的字符串:“^w+$”?
驗(yàn)證用戶密碼:“^[a-zA-Z]w{5,17}$”正確格式為:以字母開頭,長度在6-18之間,?
只能包含字符、數(shù)字和下劃線。?
驗(yàn)證是否含有^%&'',;=?$"等字符:“[^%&'',;=?$x22]+”?
只能輸入漢字:“^[u4e00-u9fa5],{0,}$”?
驗(yàn)證Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$”?
驗(yàn)證InternetURL:“^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$”?
驗(yàn)證電話號碼:“^((d{3,4})|d{3,4}-)?d{7,8}$”?
正確格式為:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”,?
“XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。?
驗(yàn)證身份證號(15位或18位數(shù)字):“^d{15}|d{}18$”?
驗(yàn)證一年的12個(gè)月:“^(0?[1-9]|1[0-2])$”正確格式為:“01”-“09”和“1”“12”?
驗(yàn)證一個(gè)月的31天:“^((0?[1-9])|((1|2)[0-9])|30|31)$”?
正確格式為:“01”“09”和“1”“31”。?
匹配中文字符的正則表達(dá)式: [u4e00-u9fa5]?
匹配雙字節(jié)字符(包括漢字在內(nèi)):[^x00-xff]?
匹配空行的正則表達(dá)式:n[s| ]*r?
匹配HTML標(biāo)記的正則表達(dá)式:/<(.*)>.*|<(.*) />/?
匹配首尾空格的正則表達(dá)式:(^s*)|(s*$)?
匹配Email地址的正則表達(dá)式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*?
匹配網(wǎng)址URL的正則表達(dá)式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)??
(1)應(yīng)用:計(jì)算字符串的長度(一個(gè)雙字節(jié)字符長度計(jì)2,ASCII字符計(jì)1)?
String.prototype.len=function(){return this.replace([^x00-xff]/g,"aa").length;}
(2)應(yīng)用:javascript中沒有像vbscript那樣的trim函數(shù),我們就可以利用這個(gè)表達(dá)式來實(shí)現(xiàn)?
String.prototype.trim = function()?
{?
return this.replace(/(^s*)|(s*$)/g, "");?
}?
(3)應(yīng)用:利用正則表達(dá)式分解和轉(zhuǎn)換IP地址?
function IP2V(ip) //IP地址轉(zhuǎn)換成對應(yīng)數(shù)值?
{?
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!")?
}?
}?
(4)應(yīng)用:從URL地址中提取文件名的javascript程序?
s="http://www.9499.net/page1.htm";?
s=s.replace(/(.*/){0,}([^.]+).*/ig,"$2") ;//Page1.htm?
(5)應(yīng)用:利用正則表達(dá)式限制網(wǎng)頁表單里的文本框輸入內(nèi)容?
用正則表達(dá)式限制只能輸入中文:οnkeyup="value=value.replace(/[^u4E00-u9FA5]/g,'') "onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^u4E00-u9FA5]/g,''))"
用正則表達(dá)式限制只能輸入全角字符: οnkeyup="value=value.replace(/[^uFF00-uFFFF]/g,'') "onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^uFF00-uFFFF]/g,''))"
用正則表達(dá)式限制只能輸入數(shù)字:οnkeyup="value=value.replace(/[^d]/g,'') "onbeforepaste= "clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^d]/g,''))"
用正則表達(dá)式限制只能輸入數(shù)字和英文:οnkeyup="value=value.replace(/[W]/g,'') "onbeforepaste="clipboardData.setData(''text'',clipboardData.getData(''text'').replace(/[^d]/g,''
以下轉(zhuǎn)自網(wǎng)絡(luò)博客:
?
另外,REPLACE也支持REGEX關(guān)鍵字。
最后:只能是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里面的雙字節(jié)字符
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里面的單字節(jié)字符
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?
總結(jié)
以上是生活随笔為你收集整理的SAP ABAP常用正则表达式大全的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Excel公式扫盲——SUMPRODUC
- 下一篇: SAP运维和SAP实施有什么区别