ABAP-字符串常用处理方法
字符串处理
SPLIT dobj AT sep INTO { {result1 result2 ...} | {TABLE result_tab} }
必须指定足够目标字段。否则,用字段dobj的剩余部分填充最后目标字段并包含分界符;或者使用内表动态接收
DATA: L_STR TYPE STRING,
L_STR1 TYPE C,
L_STR2 TYPE C. DATA: BEGIN OF LT_STR OCCURS 0,
STR TYPE C,
END OF LT_STR. L_STR = '1/2'.
SPLIT L_STR AT '/' INTO L_STR1 L_STR2. "根据‘/’截断字符创 L_STR 放于L_STR1、L_STR2
WRITE: L_STR1,L_STR2,/. SPLIT L_STR AT '/' INTO TABLE LT_STR. "根据‘/’截断字符创 L_STR 放于表LT_STR
LOOP AT LT_STR.
WRITE: LT_STR-STR,/.
ENDLOOP.
SHIFT dobj { [ {BY num PLACES} | { UP TO sub_string } ] [ [ LEFT|RIGHT ] [ CIRCULAR ] ] }
| { { LEFT DELETING LEADING } | { RIGHT DELETING LEADING } } pattern
对于固定长度字符串类型,shift产生的空位会使用空格或十六进制的0(如果为X类型串时)来填充
向右移动时前面会补空格,固定长度类型字符串与String结果是不一样:String类型右移后不会被截断,只是字串前面补相应数量的空格,但如果是C类型时,则会截断;左移后后面是否被空格要看是否是固定长度类型的字符串还是变长的String类型串,左移后C类型会补空格,String类型串不会(会缩短)
CIRCULAR:将移出的字符串放在左边或者左边
pattern:只要前导或尾部字符在指定的pattern字符集里就会被去掉,直到第一个不在模式pattern的字符止
DATA(STR) = `0123456789`.
SHIFT STR. "打印出 123456789 DATA: TEXT TYPE STRING VALUE 'I know you know',
OFF TYPE I.
FIND 'you' IN TEXT MATCH OFFSET OFF.
SHIFT TEXT BY OFF PLACES. "从 ‘you’ 的地方截断字符串TEXT,保留'you' 和之后的字符串 you know
*SHIFT TEXT UP TO 'you'. "从 ‘you’ 的地方截断字符串TEXT,保留'you' 和之后的字符串 you know DATA(TEXT) = '0123456789'.
*SHIFT TEXT RIGHT. "从右边截断第一个字符 012345678
SHIFT TEXT LEFT. "从左边截断第一个字符 123456789 SHIFT TEXT UP TO 'you' LEFT CIRCULAR. "打印出来是 ‘you know I know’
SHIFT TEXT UP TO 'you' RIGHT CIRCULAR. "打印出来是 ‘know I know you’ DATA(xstr) = CONV xstring( `AABBCCDDEEFF` ).
SHIFT xstr IN BYTE MODE. "打印出来 BBCCDDEEFF DATA TEXT TYPE STRING VALUE `I know you know `.
SHIFT TEXT RIGHT DELETING TRAILING 'no kw'. "I know you DATA TXT TYPE STRING VALUE '0000011111'.
SHIFT TXT RIGHT DELETING TRAILING '1'. "00000
SHIFT TXT LEFT DELETING LEADING '0'. "11111
CONDENSE [NO-GAPS].
如果是C类型只去掉前面的空格(因为是定长,即使后面空格去掉了,左对齐时后面会补上空格),如果是String类型,则后面空格也会被去掉;
字符串中间的多个连续的空格使用一个空格替换(String类型也是这样);
NO-GAPS:字符串中间的所有空格都也都会去除(String类型也是这样);空格去掉后会左对齐
DATA: BEGIN OF SENTENCE,
WORD1 TYPE C LENGTH 30 VALUE 'She',
WORD2 TYPE C LENGTH 30 VALUE 'feeds',
WORD3 TYPE C LENGTH 30 VALUE 'you',
WORD4 TYPE C LENGTH 30 VALUE 'tea',
WORD5 TYPE C LENGTH 30 VALUE 'and',
WORD6 TYPE C LENGTH 30 VALUE 'oranges',
END OF SENTENCE,
TEXT TYPE STRING.
TEXT = SENTENCE.
CONDENSE TEXT. " She feeds you tea and oranges
CONDENSE TEXT NO-GAPS. "Shefeedsyouteaandoranges
CONCATENATE { dobj1 dobj2 ...} | { LINES OF itab } INTO result [SEPARATED BY sep] [RESPECTING BLANKS].
C、D、N、T类型的前导空格会保留,尾部空格都会被去掉,但对String类型所有空格都会保留;对于C、D、N、T类型的字符串有一个RESPECTING BLANKS选项可使用,表示尾部空格也会保留。注:使用 `` 对String类型进行赋值时才会保留尾部空格
TYPES HEX TYPE X LENGTH 1.
DATA ITAB TYPE TABLE OF HEX WITH EMPTY KEY. ITAB = VALUE #(
( CONV HEX( '48' ) )
( CONV HEX( '65' ) )
( CONV HEX( '6C' ) )
( CONV HEX( '6C' ) )
( CONV HEX( '6F' ) ) ). CONCATENATE LINES OF ITAB INTO DATA(XSTR) IN BYTE MODE. "48656C6C6F
strlen(arg)、Xstrlen(arg)
String类型的尾部空格会计入字符个数中,但C类型的变量尾部空格不会计算入
DATA: STR TYPE STRING VALUE `12345 `,
TXT TYPE C LENGTH 10 VALUE '12345 ',
LEN TYPE I. LEN = STRLEN( STR ). "10
LEN = STRLEN( TXT ). "5
substring( val = TEXT [off = off] [len = len] )
DATA RESULT TYPE STRING.
RESULT = SUBSTRING( VAL = 'ABCDEFGH' OFF = 2 LEN = 2 ). "CD
RESULT = SUBSTRING_FROM( VAL = 'ABCDEFGH' SUB = 'CD' ). "CDEFGH
RESULT = SUBSTRING_AFTER( VAL = 'ABCDEFGH' SUB = 'CD' ). "EFGH
RESULT = SUBSTRING_BEFORE( VAL = 'ABCDEFGH' SUB = 'CD' ). "AB
RESULT = SUBSTRING_TO( VAL = 'ABCDEFGH' SUB = 'CD' ). "ABCD
count( val = TEXT {sub = substring}|{regex = regex} )
匹配指定字符串substring或正则式regex出现的子串次数,返回的类型为i整型类型
DATA(RESULT1) = COUNT( VAL = `xxx123yyy` REGEX = `\d+` ). "1
DATA(RESULT2) = COUNT_ANY_OF( VAL = `xxx123yyy` SUB = `123` ). "3
DATA(RESULT3) = COUNT_ANY_NOT_OF( VAL = `xxx123yyy` SUB = `x` ). "6
match( val = TEXT REGEX = REGEX occ = occ)
返回的为匹配到的字符串。注:每次只匹配一个。
occ:表示需匹配到第几次出现的子串。如果为正,则从头往后开始计算,如果为负,则从尾部向前计算
MATCH( VAL = 'x1 x2 x3' REGEX = 'x.' OCC = 2 ) "x2
find( val = TEXT {sub = substring}|{regex = regex}[occ = occ] )
查找substring或者匹配regex的子串的位置。如果未找到,则返回 -1,返回的为offset,所以从0开始
DATA(RESULT1) = FIND( VAL = `xxx123yyy` REGEX = `\d+` ). "3
DATA(RESULT2) = FIND_END( VAL = `xxx123yyy` REGEX = `\d+` ). "6
DATA(RESULT3) = FIND_ANY_OF( VAL = `xxx123yyy` SUB = `123` ). "3
DATA(RESULT4) = FIND_ANY_NOT_OF( VAL = `xxx123yyy` SUB = `x` ). "3
ABAP-字符串常用处理方法的更多相关文章
- python3【基础】-字符串 常用的方法
字符串一个最重要的特性就是不可修改. name.capitalize() 首字母大写 name.casefold() 大写全部变小写 name.center(50,"-") 输出 ...
- Python语言学习:字符串常用的方法
python字符串常用的方法 1. find( ):在字符串中搜索指定的值并返回它被找到的位置,如果没有找到,则返回-1 string.find(value,start,end) #value:必需, ...
- python字符串常用的方法解析
这是本人在学习python过程中总结的一些关于字符串的常用的方法. 文中引用了python3.5版本内置的帮助文档,大致进行翻译,并添加了几个小实验. isalnum S.isalnum() -> ...
- js入门之字符串常用的方法
一. 概念理解基本包装类型 1. 基本包装类型 三种基本包装类型 String var s = new String('123dddd'); Number Boolean 简单类型没有方法和属性 之所 ...
- js字符串常用判断方法
转自:http://blog.sina.com.cn/s/blog_6819fa800100j5t6.html 一.方法介绍 function obj$(id) ...
- JS操作字符串常用的方法
JS操作String对象的方法 charAt(index):返回指定索引处的字符串charCodeAt(index):返回指定索引处的字符的Unicode的值concat(str1,str2,...) ...
- python之字符串常用的方法
1. 去掉空格或换行符 s='. hello .world .\n' new_s = s.strip()#默认去掉字符串前后的空格和换行符 new_s = s.strip('.')#可传参去掉字符串前 ...
- Python字符串常用的方法——真心觉得比java,c好用
# Strings have many methods wo can use rand_string=" life is a beautiful struggle " print( ...
- js字符串常用的方法总结,及其用法
JS自带函数concat将两个或多个字符的文本组合起来,返回一个新的字符串.var a = "hello";var b = ",world";var c = a ...
- C#字符串string的常用使用方法
1--->字符串的声明: 1.string s=new string(char[] arr) //根据一个字符数组声明字符串,即将字符字组转化为字符串. 2.string s=new s ...
随机推荐
- 【小白学PyTorch】15 TF2实现一个简单的服装分类任务
[新闻]:机器学习炼丹术的粉丝的人工智能交流群已经建立,目前有目标检测.医学图像.时间序列等多个目标为技术学习的分群和水群唠嗑的总群,欢迎大家加炼丹兄为好友,加入炼丹协会.微信:cyx64501661 ...
- 使用maven整合mybatis时出现org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)
分析原因是mybatis的映射文件的问题,首先进行分析排查: 1.检查mapper接口和对应的xml文件的包名是否对应 2.检查xml文件的namespace与mapper接口的包名是否对应 3.检查 ...
- 03 sublime text3下配置Java的编译运行环境
参考如下文章,加入了自己的干货: https://blog.csdn.net/qq_38295511/article/details/81140069 https://blog.csdn.net/qq ...
- centos配置WordPress(Apache+mysql+php)
.安装Apache 安装命令:sudo yum install httpd 启动服务:sudo service httpd start 在浏览器输入IP地址,正常应该显示Apache的欢迎页面 如果提 ...
- 引用类型之Array(二)
操作方法 concat( ) concat() 方法用于连接两个或多个数组. 该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本. 语法 arrayObject.concat(arrayX,a ...
- Spring Boot第七弹,别再问我拦截器如何配置了!!!
持续原创输出,点击上方蓝字关注我吧 前言 上篇文章讲了Spring Boot的WEB开发基础内容,相信读者朋友们已经有了初步的了解,知道如何写一个接口. 今天这篇文章来介绍一下拦截器在Spring B ...
- python中random的一些用法
#(1)随机小数 import random print(random.random()) #随机大于0 且小于1 之间的小数 ''' 0.9441832228391154 ''' print(ra ...
- 使用响应扩展的响应面(Rx)
下载demo - 196 KB 下载source - 98 KB 表的内容 系统要求反应面一个简单的计时器从事件中收集数据序列使用更复杂的查询订阅您希望完成的面最终考虑历史 介绍 "Rx&q ...
- ActiveMQ详细入门教程系列(一)
一.什么是消息中间件 两个系统或两个客户端之间进行消息传送,利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成.通过提供消息传递和消息排队模型,它可以在分布式环境下 ...
- 2020年了,IT外企还香吗?
本来是刚发了<世上有不用加班的程序员吗?>,有朋友问到IT外企不加班福利好什么的,就回复了几句. 老王观点: 现在IT外企已经不值得羡慕了,08.09年那会,ibm,惠普还是香饽饽,当时人 ...