ABAP语法基础篇(5)——字符串处理


五、字符串

5.1 移动字符串

5.1 .1 按给定位置数移动字符串

要按给定位置数移动字 段内容, 使用 SHIFT 语句,用法如下:

SHIFT [BY PLACES] [].

该语句将字段 移动 个位置。如果省略 BY PLACES ,则将 解释为一个位置。如果 是0 或负值,则 保持不变。如果 超过 长度,则 用空格填充, 可为变量。

对不同( )选项,可以按以下方式移动字段

LEFT: 向左移动 位置,右边用 个空格填充(默认设置)。

RIGHT: 向右移动 位置,左边用 个空格填充。

CIRCULAR : 向左移动 位置,以便左边 个字符出现在右边。

5.1.2 移动字符串到给定串位置

要移动字段内容以到给定串位置 ,则使用 SHIFT 语句,用法如下:

SHIFT UP TO .

ABAP/4 查找 字段内容直到找到字符串 并将字段 移动到字段边缘。 选项与按给定位置数移动字符串中所述相同, 可为变量。

如果 中找不到 ,则将 SY-SUBRC 设置为 4 并且不移动 。否则,将 SY-SUBRC 设置为 0 。

5.1.3 根据第一个或最后一个字符移动字符串

假设第一个或最后一个字符符合一定条件,则可用 SHIFT 语句将字段向左或向右移动。为此,请使用以下语法:

SHIFT LEFT DELETING LEADING .

SHIFT RIGHT DELETING TRAILING .

假设左边的第一个字符或右边的最后一个字符出现在 中,该语句将字段 向左或向右移动。字段右边或左边用空格填充, 可为变量。

5.2 替换字段内容

要用其它字符串替换字段串的某些部分, 使用 REPLACE 语句。

REPLACE WITH INTO [LENGTH ].

ABAP/4 搜索字段 中模式 个位置第一次出现的地方。如果未指定长度,按全长度搜索模式 。然后,语句将模式 在字段 中第一次出现的位置用字符串 替换。

如果指定长度 ,则只替换模式的相关部分。如果将系统字段 SY-SUBRC 的返回代码设置为 0 ,则说明在 中找到 且已用 替换。非 0 的返回代码值意味着未替换。 可为变量。

5.3 大小写转换 并替换字符串

可以将字母转换大 / 小写或使用替换规则。要转换大 / 小 写, 使用 TRANSLATE 语句,用法如下:

TRANSLATE TO UPPER CASE.

TRANSLATE TO LOWER CASE.

这些语句将字段 中的所有小写字母转换成大写或反之。

使用替换规则时, 使用以下语法:

TRANSLATE USING .

该语句根据字段 中存储的替换规则替换字段 的所有字符。 包含成对字母,其中每对的第一个字母用第二个字母替换。 可为变量。

5.4 转换为可排序格式

可以将字符字段转换为可按字母顺序排列的格式:

CONVERT TEXT INTO SORTABLE CODE .

该语句为字符字段 填充可排序目标字段 。字段 必须是类型 C 且字段 必须是类型 X ,最小长度为 长度的 16 倍。
该语句目的是为字符字段 创建相关字段 ,作为 的按字母顺序排列的排序关键字。在内表的内容和已解压缩的数据中进行排序。

如果对未转换的字符字段进行排序,则系统创建与各字母的特定平台内部编码相对应的顺序。在对目标字段进行排序之后,转换 CONVERT TEXT 按这样的方式创建目标字段,相应的字符字段顺序按字母排序。例如,在德语中,顺序为Miller 、 Moller 、 Mller 、 Muller ,而不是 Miller 、 Moller 、 Muller 、 Mller

转换方法依赖于运行 ABAP/4程序的文本环境。文本环境在用户主记录中定义。例外的是可以使用如下语句,在程序中设置文本环境:

SET LOCALE LANGUAGE [COUNTRY ] [MODIFIER ].

该语句根据语言 设置文本环境。对于选项 COUNTRY,只要特定国家语言不同,就可以在语言以外指定国家。对于选项 MODIFIER,只要一个国家内语言不同,就可以指定另一个标识符,例如,排序顺序在电话簿和词典之间不同。

字段 必须是类型 C 且长度必须与表 TCP0C的关键字段长度相等。表 TCP0C 是一个表格,从中进行平台相关的文本环境维护。在语句 SET LOCALE 期间,系统根据TCP0C 中的条目设置文本环境。除了内部传送的平台特性之外,用 SET 语句指定表关键字。如果 等于 SPACE,则系统根据用户主记录设置文本环境。如果对于指定的关键字在表中无条目,则系统将产生运行错误。
文本环境影响 ABAP/4 中依赖于字符集的所有操作。

5.5 覆盖字符字段

要用另一字符字段覆盖字符字段,使用 OVERLAY 语句,用法如下:

OVERLAY WITH [ONLY ].

该语句用 的内容覆盖字段 中包含 中字母的所有位置。 保持不变。如果省略 ONLY ,则覆盖字段 中所有包含空格的位置。

如果至少要替换 中的一个字符,则将 SY-SUBRC 设置为 0。对于所有其它情况,将 SY-SUBRC 设置为 4 。如果 长,则只覆盖 中的长度。

5.6 搜索字符串

要搜索特定模式的字符串,请使用 SEARCH 语句,用法如下:

SEARCH FOR .

该语句在字段 中搜索 中的字符串。如果成功,则将 SY-SUBRC 的返回代码值设置为 0 并将 SY-FDPOS 设置为字段 中该字符串的偏移量。否则将 SY-SUBRC 设置为 4 。

搜索串 可为下列格式之一:

目的
搜索 (任何字符顺序), 忽略尾部空格
.. 搜索 ,但是不忽略尾部空格
* 搜索以 结尾的词
* 搜索以 开始的词

单词之间用空格、逗号、句号、分号、冒号、问号、叹号、括号、斜杠、加号和等号等分隔。
搜索字符字段 的各种选项如下:

  • ABBREVIATED

在字段 中搜索包含 中指定字符串的单词,其中字符可能被其它字符隔开。单词和字符串的第一个字母必须相同。

  • STARTING AT

在字段 中搜索从 开始的 。结果 SY-FDPOS 参照相对于 的偏移量而不是字段的开始。

  • ENDING AT

在字段 搜索 直到位置

  • AND MARK

如果找到搜索串,则将搜索串中的所有字符(和使用 ABBREVIATED时的所有字符)转换为大写形式。

5.7 获得字符串长度

要决定字符串到最后一个字符而不是 SPACE 的长度, 使用内部函数 STRLEN ,用法如下:

[COMPUTE] = STRLEN( ).

STRLEN 将操作数 作为字符数据类型处理,而不考虑其实际类型,不进行转换。关键字 COMPUTE 可选。

5.8 压缩字符串去空格

要删除字符字段中多余 空格,使用 CONDENSE 语句,用法如下:

CONDENSE [NO-GAPS].

该语句去除字段 中的前导空格并用一个空格替换其它空格序列。结果是左对齐单词,每个单词用空格隔开。如果指定附加的 NO-GAPS ,则去除所有空格。

5.9 连接字符串

要将单个字符串连接成一体, 使用 CONCATENATE 语句,用法如下:

CONCATENATE ... INTO [SEPARATED BY ].

该语句连接字符串 并将结果赋给

该操作忽略尾部空格,附加 SEPARATED BY 允许指定字符字段 ,它放置在单个字段间已定义的长度中。
如果结果符合 ,则将 SY-SUBRC 设置为 0 。然而,如果结果必须被截断,则将 SY-SUBRC 设置为 4 。

5.10 拆分字符串

要将字符串拆分成两个或更多小串 , 使用 SPLIT 语句,用法如下:

SPLIT AT INTO ... .

该语句在字符字段 搜索分界字符串 ,并将分界符之前和之后的部分放到目标字段 ... 中。

要将所有部分放到不同目标字段中,必须指定足够目标字段。否则,用字段 的剩余部分填充最后目标字段并包含分界符。

如果所有目标字段足够长且不必截断任何部分,则将 SY-SUBRC 设置为 0 ,否则,将其设置为 4 。

5.11 分配字符串部分

MOVE 语句的以下变体只使用类型 C 字段:

MOVE TO PERCENTAGE

[RIGHT].

将左对齐的字符字段 的百分比

(或如果用 RIGHT 选项指定,则为右对齐)复制到

值可为 0100 之间的任何数。将要从 复制的长度取整为下一个整数。

如果语句中某一参数不是类型 C ,则忽略参数 PERCENTAGE