gpt4 book ai didi

json - 通过 ST 转换处理 JSON 反序列化中的空值?

转载 作者:行者123 更新时间:2023-12-04 08:02:06 24 4
gpt4 key购买 nike

JSON 到 ABAP 的问题。这是一个 高度简化的例子,但试图捕获要点。每一个 JSON 元素(除了少数异常(exception))都可能带有真实值、带有空值或根本不存在。
在此示例中,有 3 个订单项。订单项可能有也可能没有 order_reason。对于第 01 行它是 ABC,对于第 02 行它是空的,对于第 03 行它根本不存在。
如果您查看 XML,您可以看到创建的元素因内容而异,我不知道如何在我的 ST 中处理它。我想这是某种条件或组或开关,但我似乎找不到正确的语法来检查元素有时是“空”还是有时是“字符串”。因此,它不是对元素内容的检查,而是对实际元素本身的检查。
super 简单的 JSON

    {
"order_id": "564320",
"items": [
{
"line": "01",
"order_reason": "ABC"
},
{
"line": "02",
"order_reason": null
},
{
"line": "03"
}
]
}
然后将其隐式转换为 XML 以在 ST 中进行处理。 Order Reason 元素是 表示第一项,然后 表示第二项,最后一行缺少。
    <object>
<str name="order_id">564320</str>
<array name="items">
<object>
<str name="line">01</str>
<str name="order_reason">ABC</str>
</object>
<object>
<str name="line">01</str>
<null name="order_reason" />
</object>
<object>
<str name="line">03</str>
</object>
</array>
</object>
这是我的示例 ST。
    <?sap.transform simple?>
<tt:transform xmlns:tt="http://www.sap.com/transformation-templates" >
<tt:root name="ROOT" />
<tt:template>
<object>
<str name="order_id">
<tt:value ref="ROOT.order_id"/>
</str>
<array>
<tt:loop ref="ROOT.items">
<object>
<str name="line">
<tt:value ref="$ref.posnr"/>
</str>
<str name="order_reason">
<tt:value ref="$ref.reason"/>
</str>
</object>
</tt:loop>
</array>
</object>
</tt:template>
</tt:transform>
这是一个可执行的 ABAP 来测试上述内容。有两个版本的 JSON 需要测试。第一个有效,因为每个项目都有一个原因代码。检查这个只是为了确保一切都在快乐的情况下工作。通过切换到代码中的第二个示例,您可以看到需要处理 元素而不是 元素。所以不是元素的内容,而是预期的元素本身。我试图对元素 进行存在检查,但这似乎不起作用(或者实际上我不知道引用当前元素的类型/名称的语法)。
*&---------------------------------------------------------------------*
*& Report Z_JSON_ABAP
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
REPORT z_json_abap2.

CLASS demo DEFINITION.
PUBLIC SECTION.
CLASS-METHODS main.
ENDCLASS.

CLASS demo IMPLEMENTATION.
METHOD main.

TYPES: BEGIN OF ty_s_line,
posnr TYPE posnr,
reason TYPE char3,
END OF ty_s_line.

TYPES: BEGIN OF ty_s_header,
order_id TYPE vbeln,
items TYPE TABLE OF ty_s_line WITH DEFAULT KEY,
END OF ty_s_header.

DATA: lt_order TYPE ty_s_header.

* Example 1 - Works - Easy!
DATA(lv_json) = cl_abap_codepage=>convert_to(
`{` &&
` "order_id": "51324", ` &&
` "items": [ ` &&
` { ` &&
` "line": "01", ` &&
` "order_reason": "ABC" ` &&
` }, ` &&
` { ` &&
` "line": "02", ` &&
` "order_reason": "DEF" ` &&
` }, ` &&
` { ` &&
` "line": "03", ` &&
` "order_reason": "123" ` &&
` } ` &&
` ] ` &&
` } ` ).


* Example 2 - Does not work! - Swap sections to test

* DATA(lv_json) = cl_abap_codepage=>convert_to(
* `{` &&
* ` "order_id": "51324", ` &&
* ` "items": [ ` &&
* ` { ` &&
* ` "line": "01", ` &&
* ` "order_reason": "ABC" ` &&
* ` }, ` &&
* ` { ` &&
* ` "line": "02", ` &&
* ` "order_reason": null ` &&
* ` }, ` &&
* ` { ` &&
* ` "line": "03" ` &&
* ` } ` &&
* ` ] ` &&
* ` } ` ).

CALL TRANSFORMATION zst_order_test SOURCE XML lv_json RESULT root = lt_order.

ENDMETHOD.

ENDCLASS.

START-OF-SELECTION.
demo=>main( ).

最佳答案

原来这太简单了。我可能盯着它看得太久了,用组和开关等想象了一些过于复杂的解决方案。也许这甚至是可能的,但这是有效的。刚刚添加了两个条件元素。

<?sap.transform simple?>
<tt:transform xmlns:tt="http://www.sap.com/transformation-templates">
<tt:root name="ROOT"/>
<tt:template>
<object>
<str name="order_id">
<tt:value ref="ROOT.order_id"/>
</str>
<array>
<tt:loop ref="ROOT.items">
<object>
<str name="line">
<tt:value ref="$ref.posnr"/>
</str>
<tt:cond>
<str name="order_reason">
<tt:value ref="$ref.reason"/>
</str>
</tt:cond>
<tt:cond>
<null name="order_reason">
<tt:value ref="$ref.reason"/>
</null>
</tt:cond>
</object>
</tt:loop>
</array>
</object>
</tt:template>
</tt:transform>

关于json - 通过 ST 转换处理 JSON 反序列化中的空值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66407706/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com