前零和末尾零是指分别出现在数字序列中第一个非零数字之前和最后一个非零数字之后的任何零数字。
关于前导 0
在 SAP 系统中,大多数字母数字字段在数据库中存储时都带前导零,完全占用字段的定义长度。但是,当字段显示给最终用户时,前导零就被省略掉了。
SAP 通过使用所谓的转换出口将数值从外部(输出)格式转换为内部(输入)格式来处理这种数据规范化过程。
添加或删除前导零是 ABAP 开发人员日常生活中的常见要求。随着语法的不断发展,实现上述要求的可能性也越来越多。
转换退出示例
下面的示例使用的是订单号数据元素 AUFNR,其数据类型为 CHAR,长度为 12。
ABAP
DATA(lv_order_number) = CONV aufnr( 12345 ).
在 ABAP 字典中打开我们要转换的字段域,就会发现我们可以使用 "ALPHA "转换例程。开发人员可以使用这些功能模块在大多数数字/ID 类型字段中添加和删除前导零。
ABAP 词典中的域 AUFNR (SE11
):
函数模块
在过去,ALPHA 转换例程的功能模块是添加和删除零的最佳方法。
ABAP
DATA(lv_order_number) = CONV aufnr( 12345 ).
WRITE |{ lv_order_number }|. "Output: 12345
"Add leading zeros
CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
EXPORTING
input = lv_order_number
IMPORTING
output = lv_order_number.
WRITE |{ lv_order_number }|. "Output: 000000012345
"Remove leading zeros
CALL FUNCTION 'CONVERSION_EXIT_ALPHA_OUTPUT'
EXPORTING
input = lv_order_number
IMPORTING
output = lv_order_number.
WRITE |{ lv_order_number }|. "Output: 12345
使用字符串模板的简易形式
自从 ABAP 7.4 中的字符串模板和 ABAP 7.2 中的嵌入式 ALPHA 表达式出现后,ALPHA 转换的结果就可以在一行中实现。
ABAP
DATA(lv_order_number) = CONV aufnr( 12345 ).
WRITE |{ lv_order_number }|. "Output: 12345
lv_order_number = |{ lv_order_number ALPHA = IN }|.
WRITE |{ lv_order_number }|. "Output: 000000012345
lv_order_number = |{ lv_order_number ALPHA = OUT }|.
WRITE |{ lv_order_number }|. "Output: 12345
带构造函数运算符 CONV 的内联声明
我们甚至可以在一行中声明一个变量并填充前导零,这样就不需要可能的辅助变量了。
ABAP
DATA(lv_order_number) = CONV aufnr( |{ '12345' ALPHA = IN }| ).
WRITE |{ lv_order_number }|. "Output: 000000012345
其他例子
用 SHIFT 删除前导零
SHIFT
语句可用于删除零字符串。
ABAP
DATA(lv_order_number) = CONV aufnr( |{ '12345' ALPHA = IN }| ).
WRITE |{ lv_order_number }|. "Output: 000000012345
SHIFT lv_order_number LEFT DELETING LEADING '0'.
WRITE |{ lv_order_number }|. "Output: 12345
用 OVERLAY 添加尾数零
OVERLAY
语句可用于为字符串填充尾部的零。
ABAP
DATA(lv_order_number) = CONV aufnr( 12345 ).
WRITE |{ lv_order_number }|. "Output: 12345
"Helper variable of type string, without any leading or trailing zeros
DATA(lv_order_number_string) = |{ lv_order_number ALPHA = OUT }|.
OVERLAY lv_order_number_string WITH '000000000000'.
WRITE |{ lv_order_number_string }|. "Output: 123450000000