问题描述
我的问题是将if语句集成到字符串模板中。
TYPES: BEGIN OF ty_field,name TYPE string,label TYPE string,result TYPE string,END OF ty_field.
DATA: mt_fields TYPE TABLE OF ty_field.
mt_fields = VALUE #(
( name = 'HI' label = 'Greeting' )
( name = 'PERSON' label = 'Who' )
( name = 'RESULT' label = 'Sentence' result = |Say \{HI\} to \{PERSON\}.| ) ).
不幸的是,mt_fields
的第3行将result
设置为Say {HI} to {PERSON}
,但我希望Say Greeting to Who
。
更重要的是,我想获得的东西:
有时没有PERSON
的数据。在这种情况下,结果变量将获得字符串'Say hello to .'
(如果'hello'
是HI
的值)。
我不想吃这个。如果没有人,我希望得到一个空字符串。因此,无论是否有PERSON
的值,我都必须先过滤。我需要将if条件放入字符串分配中。
在Python中,我会写类似
( name = 'RESULT' label = 'Sentence' result = 'Say {HI} to {PERSON}.' IF PERSON != '' ELSE '' )
但是如何在ABAP中做到这一点?
非常感谢!
解决方法
如果我正确理解了您要做什么:
TYPES: BEGIN OF ty_field,name TYPE string,label TYPE string,result TYPE string,END OF ty_field.
DATA: mt_fields TYPE TABLE OF ty_field.
mt_fields = VALUE #( let salutation = 'Greeting' pers = cond string( when salutation = 'Hello' then '' else 'Who' ) IN
( name = 'HI' label = salutation )
( name = 'PERSON' label = pers )
( name = 'RESULT' label = 'Sentence' result = |Say { salutation } to { pers }.| ) ).