日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

SAP ABAP常用正则表达式大全

發(fā)布時(shí)間:2025/3/20 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 SAP ABAP常用正则表达式大全 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

特殊表達(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)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。