ABAP-08 字符串处理 - 重点
1、字符串的基本操作
1.1 连接字符串
CONCATENATE {c1} … {cn} INTO {c} [SEPARATED BY {s}]
CONCATENATE只能拼接字符型字段
*字符串连接。
DATA i_str1(10) TYPE c.
DATA i_str2(20) TYPE c.
DATA o_RS TYPE string.
i_str1 = 'LION'.
i_str2 = 'HELLO'.
CONCATENATE I_STR1 I_STR2 INTO O_RS.
WRITE: O_RS,/." 输出:LIONHELLO.
CONCATENATE I_STR1 I_STR2 INTO O_RS SEPARATED BY '/'.
WRITE: O_RS,/." 输出:LION/HELLO.
ULINE.
以下会报错
*字符串连接。
DATA i_str1(10) TYPE c.
DATA i_str2(20) TYPE c.
DATA i_str3 TYPE i.
DATA o_rs TYPE string.
i_str1 = 'LION'.
i_str2 = 'HELLO'.
i_str3 = 100.
CONCATENATE i_str1 i_str2 i_str3 INTO o_rs." 此处会报错,提示i_str3必须要是字符型
1.2 拆分字符串
SPLIT {c} AT {del} INTO {c1} … {cn}.
DATA a(10) TYPE c VALUE 'hello'.
DATA b(20) TYPE c VALUE 'word'.
DATA:c(10) TYPE c,
d(20) TYPE c,
all TYPE string.
CONCATENATE a b INTO all SEPARATED BY '/'.
WRITE: all."输出:hello/word。
SPLIT all AT '/' INTO c d.
WRITE: / c."输出:hello
WRITE / d."输出:word
注:1、当拆分时,into后面的字段不够时,最后一个字段放剩余的所有内容
DATA a(10) TYPE c VALUE 'hello'.
DATA b(20) TYPE c VALUE 'word'.
DATA:c(10) TYPE c,
d(20) TYPE c,
e(20) type c,
all TYPE string.
CONCATENATE a b '!' INTO all SEPARATED BY ' '.
WRITE: all."输出:hello word。
*拆分后字段不足的
SPLIT all AT ' ' INTO c d.
WRITE: / c."输出:hello
WRITE / d."输出:word !
*拆分后字段足够的
SPLIT all AT ' ' INTO c d e.
WRITE: / c."输出:hello .
WRITE / d."输出:word .
WRITE / e."输出:! .
注:不知道能拆分多少个时,把拆分后的先放表格table中,然后再取出
DATA a(10) TYPE c VALUE 'hello'.
DATA b(20) TYPE c VALUE 'word'.
DATA:c(10) TYPE c,
d(20) TYPE c,
e(20) type c,
all TYPE string.
CONCATENATE a b '!' INTO all SEPARATED BY ' '.
WR