繁体   English   中英

如何使用 dataweave 2.0 解析带有转义 json 的字符串

[英]how to parse a string with escaped json using dataweave 2.0

我需要解析 API 的响应,如下所示:

"[{\"Customers\":[{\"Id\":1607715391563}],\"Partners\":[],\"ModDate\":\"\\/Date(1608031919597)\\/\",\"CreatedByUserId\":null},{\"Message\":null,\"Code\":\"200\",\"NextPage\":1}]"

我希望我有这样的:

[
   {
      "Customers":[
         {
            "Id":1607715391563
         }
      ],
      "Partners":[
         
      ],
      "ModDate":"/Date(1608031919597)/",
      "CreatedByUserId":null
   },
   {
      "Message":null,
      "Code":"200",
      "NextPage":1
   }
]

我已经尝试使用payload[1 to -2]删除字符串,并使用read(payload[1 to -2], 'application/json')解析 JSON 。 我已经尝试遵循此链接的一些提示,但均未成功。

编辑:这里的重点是我想访问,例如,其他连接器中的 Customers.Id 值,但我不能

这个怎么样?

在此处输入图像描述

%dw 2.0
output application/json
var inpString = "[{\"Customers\":[{\"Id\":1607715391563}],\"Partners\":[],\"ModDate\":\"\\/Date(1608031919597)\\/\",\"CreatedByUserId\":null},{\"Message\":null,\"Code\":\"200\",\"NextPage\":1}]"
---
read(inpString,"application/json")

您可以尝试以下 DataWeave 表达式:

%dw 2.0
output application/json
---
read((payload replace /^"|"$/ with '') replace '\"' with '"', "application/json")

第一个替换将删除标题和尾随双引号,第二个替换将用双引号替换反斜杠双引号。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM