![](/img/trans.png)
[英]How to replace specific value in Json based on condition in Mule(3) Dataweave 1.0
[英]Mule Dataweave Replace Null with Specific Value
我的请求有效负载如下所示:
{
"AllCodes": [
{
"Code1": "ABC"
},
{
"Code2": "TUV"
},
{
"Code3": "XYZ"
}
]
}
我有一个函数,它将用特定值替换上面的值。 我现在的代码如下:
%dw 1.0
%output application/json
%function LookUp(codes) codes mapObject {($$): $.code} //function to return string values for above codes
%var codeLookup = LookUp(sessionVars.OutputCodes)
%var FinalCodes = payload.AllCodes map codeLookup[$] joinBy ';'
--
FinalCodes
sessionVars.OutputCodes的输出是:
{
"CodeMaster": {
"PrimaryCodes": {
"PrimarySpecCodes": {
"ABC": {
"code": "ABC-String1"
},
"TUV": {
"code": "TUV-String2"
}
}
}
}
}
我期望的输出是:
"ABC-String1;XYZ-String2;XYZ"
如上所示,由于该函数仅返回“ ABC”和“ TUV”代码的值,因此如果未找到函数值,则最终输出应具有原始值。
我试图在地图运算符之前使用默认值。 但这似乎不起作用。
我们获得$ pluck $
allCodes
$ pluck $
allCodes
所有值,然后,如果未找到codes[$]
,则默认为$
。 我相信您只需要在原始dataweave中添加default $
即可使用,但是我为StackOverflow上的其他用户提供了完整的解决方案。
%dw 1.0
%output application/json
%var outputCodes =
{
"CodeMaster": {
"PrimaryCodes": {
"PrimarySpecCodes": {
"ABC": {
"code": "ABC-String1"
},
"TUV": {
"code": "TUV-String2"
}
}
}
}
}
%var allCodes =
{
"AllCodes": [
{
"Code1": "ABC"
},
{
"Code2": "TUV"
},
{
"Code3": "XYZ"
}
]
}
%var codes = outputCodes.CodeMaster.PrimaryCodes.PrimarySpecCodes mapObject {
($$): $.code
}
---
(flatten (allCodes.AllCodes map ($ pluck $))) map (
codes[$] default $
) joinBy ';'
这将产生:
"ABC-String1;TUV-String2;XYZ"
有多种解决方法。 一种可能如下:
%dw 1.0
%output application/json
%var payload2= { "CodeMaster": { "PrimaryCodes": { "PrimarySpecCodes": { "ABC": {"code": "ABC-String1"}, "TUV": {"code": "TUV-String2"} } } } }
%var codes = payload2.CodeMaster.PrimaryCodes.PrimarySpecCodes mapObject {
($$) : $.code
}
%var finalCodes = (payload.AllCodes map {
a: $ mapObject {
a1: codes[$] default $
}
}.a.a1) joinBy ";"
---
finalCodes
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.