首页 > 解决方案 > 在地图迭代中获取父索引

问题描述

我的任务是将 3 级结构“扁平化”为 2 级结构。

我正在迭代 XML 中的 3 级结构,并将“Level3”字段映射到“Level2”,这工作得很好,但我还需要“Level3”映射之一中的“Level2”索引。

所以我的问题是“在迭代 Level3 时获取 Level2.index()”。

希望你能帮忙:-)

XML structure (IN):
-----------------------
<?xml version="1.0" encoding="UTF-8"?>
<ns:Level1 xmlns:ns="urn:aaaa:bbbb:cccc">
  <Level2>
    <Level3>
    </Level3>
    <Level3>
    </Level3>
  </Level2>
  <Level2>
    <Level3>
    </Level3>
    <Level3>
    </Level3>
  </Level2>
</ns:Level1>

XML structure (OUT):
-----------------------
<?xml version="1.0" encoding="UTF-8"?>
<ns:Level1 xmlns:ns="urn:aaaa:bbbb:cccc">
  <Level2>
  </Level2>
  <Level2>
  </Level2>
  <Level2>
  </Level2>
  <Level2>
  </Level2>
</ns:Level1>


Dataweave 2.0 Code:
-----------------------
(payload.ns0#Level1.*Level2.*Level3 map ( level3 , indexOfLevel3 ) -> {
  Level3Index: payload.ns0#Level1.*Level2.index()?? "",
})

标签: muledataweave

解决方案


最简单的方法是嵌套到地图并使用对象扩展功能将它们展平。动态元素文档

%dw 2.0
output application/xml
---
Level1: {
    ( //Flatten all Level2
        payload.Level1.*Level2 map ((item, level2Index) -> 
            {
                (//Flatten all the level 3 under level2
                    item.*Level3 map ((item, level3Index) -> {
                        Level3: level2Index
                    })
                )
            }
        )
    )
}

推荐阅读