有时在进行字符串处理的时候,需要将字符串中的数字提取出来,这个数字可能是金额或者数量。
比如:需要将‘2.5 days’中的2.5提取出来。
通过函数 PREPARE_STRING可以快速实现这个功能。此函数可以用来实现将字符串中非法字符删除的功能,也就是保留字符串中想要的字符。
输入参数:
I_VALID_CHARS:被操作字符串中需要保留的字符
修改参数:
C_STRING:被操作的字符串
SE37测试,
注意:在SE37中I_VALID_CHARS参数中会默认‘空格’也算一个有效字符,所以函数返回结果是‘ 13 2’,
13和2之间保留了空格。
例子程序:
注意:一定要在输入参数 i_valid_chars 中加入一个空格,否则会死循环。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
REPORT ztest_prepare_string.
DATA:l_c(60) TYPE c VALUE ` 2.33 days`.
WRITE:l_c.
CALL FUNCTION 'PREPARE_STRING'
EXPORTING
i_valid_chars = ' 1234567890.,'
i_xvalid_check = 'X'
i_xchar_repl = 'X'
i_xtoupper = 'X'
CHANGING
c_string = l_c.
WRITE:/ l_c.
|
结果显示:实现了将‘2.33 days’中的数字提取出来。
以上。