ABAP
Vanliga uttryck
Sök…
Byter ut
REPLACE uttalandet kan arbeta med vanliga uttryck direkt:
DATA(lv_test) = 'The quick brown fox'.
REPLACE ALL OCCURRENCES OF REGEX '\wo' IN lv_test WITH 'XX'.
Variabeln lv_test kommer att utvärderas till The quick bXXwn XXx .
Sökande
FIND uttalandet kan arbeta med vanliga uttryck direkt:
DATA(lv_test) = 'The quick brown fox'.
FIND REGEX '..ck' IN lv_test.
" sy-subrc == 0
FIND REGEX 'a[sdf]g' IN lv_test.
" sy-subrc == 4
Objektorienterade regelbundna uttryck
För mer avancerade regex-operationer är det bäst att använda CL_ABAP_REGEX och relaterade klasser.
DATA: lv_test TYPE string,
lo_regex TYPE REF TO cl_abap_regex.
lv_test = 'The quick brown fox'.
CREATE OBJECT lo_regex
EXPORTING
pattern = 'q(...)\w'.
DATA(lo_matcher) = lo_regex->create_matcher( text = lv_test ).
WRITE: / lo_matcher->find_next( ). " X
WRITE: / lo_matcher->get_submatch( 1 ). " uic
WRITE: / lo_matcher->get_offset( ). " 4
Utvärdering av regelbundna uttryck med en predikatfunktion
Predikatet funktions matches kan användas för att utvärdera strängar i farten utan användning av något föremål deklarationer.
IF matches( val = 'Not a hex string'
regex = '[0-9a-f]*' ).
cl_demo_output=>display( 'This will not display' ).
ELSEIF matches( val = '6c6f7665'
regex = '[0-9a-f]*' ).
cl_demo_output=>display( 'This will display' ).
ENDIF.
Skaffa undermatch med OO-regulära uttryck
Genom att använda metoden GET_SUBMATCH i klass CL_ABAP_MATCHER kan vi få CL_ABAP_MATCHER i grupperna / undergrupperna.
Mål: få symbolen till höger om nyckelordet 'Type'.
DATA: lv_pattern TYPE string VALUE 'type\s+(\w+)',
lv_test TYPE string VALUE 'data lwa type mara'.
CREATE OBJECT ref_regex
EXPORTING
pattern = lv_pattern
ignore_case = c_true.
ref_regex->create_matcher(
EXPORTING
text = lv_test
RECEIVING
matcher = ref_matcher
).
ref_matcher->get_submatch(
EXPORTING
index = 0
RECEIVING
submatch = lv_smatch.
Den resulterande variabeln lv_smatch innehåller värdet MARA .
Modified text is an extract of the original Stack Overflow Documentation
Licensierat under CC BY-SA 3.0
Inte anslutet till Stack Overflow