如何在字符串中提取数字[PREPARE_STRING]
有时在进行字符串处理的时候,需要将字符串中的数字提取出来,这个数字可能是金额或者数量。
比如:需要将‘2.5 days’中的2.5提取出来。
通过函数 PREPARE_STRING可以快速实现这个功能。此函数可以用来实现将字符串中非法字符删除的功能,也就是保留字符串中想要的字符。
输入参数:
I_VALID_CHARS:被操作字符串中需要保留的字符
修改参数:
C_STRING:被操作的字符串
SE37测试,
注意:在SE37中I_VALID_CHARS参数中会默认‘空格’也算一个有效字符,所以函数返回结果是‘ 13 2’,
13和2之间保留了空格。
例子程序:
注意:一定要在输入参数 i_valid_chars 中加入一个空格,否则会死循环。
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’中的数字提取出来。
以上。