如何在字符串中提取数字[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’中的数字提取出来。

以上。

posted @ 2019-08-30 10:43  真的是很难  阅读(1028)  评论(0编辑  收藏  举报