正则表达式比较复杂,然而会用正则表达式,秒杀很多程序员,因为他人写了一堆的烂代码,你一句就搞定了。
se24 CL_ABAP_MATCHER
练习 1:
^[0-9]+abc$
^ 为匹配输出字符串的开始地位。
[0-9]+ 匹配多个数字,[0-9] 匹配单个数字,+ 匹配一个或者多个。
abc$ 匹配字母 abc 并以 abc 结尾,$ 为匹配输出字符串的完结地位。
下面这个正则表达式 翻译进去就是 ^ 开始搜寻 0 到 9 的任何数字,并且还加一个 abc 结尾的。
用 abap 语言来测试
DATA: matcher TYPE REF TO cl_abap_matcher,
match TYPE match_result,
itab TYPE match_result_tab,
line LIKE LINE OF itab.
matcher = cl_abap_matcher=>create(pattern = '^[0-9]+abc$' text = '123abc' ).
itab = matcher->find_all( ).
LOOP AT itab INTO line.
WRITE: / matcher->text,line-offset,line-length,matcher->text+line-offset(line-length).
ENDLOOP.
运行后果:
123abc 0 6 123abc