Logic Apps Liquid连接器 - 转换XML

时间:2018-02-22 13:05:50

标签: json xml azure-logic-apps dotliquid

使用Liquid map,我们可以将简单的XML转换为JSON,例如这个XML:

<root>
   <product>
      <name>TV</name>
      <price>499.9</price>
   </product>
</root>

我们可以应用此液体地图并获得有效的JSON:

{
   "name": "{{content.product.name}}",
   "price": {{content.product.price}},
}

如果源XML具有名称空间,如何实现相同的映射,例如:

<ns0:root xmlns:ns0="http://customnamespace.com" xmlns:ns1="http://customnamespace2.com">
   <ns1:product>
      <ns1:name>TV</ns1:name>
      <ns1:price>499.9</ns1:price>
   </ns1:product>
</ns0:root>

1 个答案:

答案 0 :(得分:1)

解决方案是将XML转换为JSON并在我们的Liquid map中使用括号表示法:

{    
    "First" : "{{ content['ns0:X12_00401_850'].ST.ST01 }}"
}

对于输入XML转换为JSON,如下所示:

{
  "content": {
    "ns0:X12_00401_850": {
      "@xmlns:ns0": "http://schemas.microsoft.com/BizTalk/EDI/X12/2006",
      "ST": {
        "ST01": "850",
        "ST02": "476810004"
      },