使用Mule Expression Language和Regex从字符串中获取十进制值

时间:2018-02-16 18:18:13

标签: regex mule mule-studio anypoint-studio mule-esb

此问题涉及Mule的MEL和正则表达式。我有以下JSON有效负载。

    {
       "balance": "{Amount={BasicAmount=604.45, MinimumAmount=60 445, CurrencyCode=USD}}"
    }

我可以访问余额

表示的字符串
    {Amount={BasicAmount=604.45, MinimumAmount=60 445, CurrencyCode=USD}}

我需要以字符串形式访问浮点数604.45并将其应用为流变量。因此,我在我的mule应用程序中实现了以下代码。

    <set-variable variableName="balanceUnrefined" value="#[json:balance]" doc:name="balanceUnrefined"/>
    <logger message="#[flowVars.balanceUnrefined]" level="INFO" doc:name="Logger"/>
    <set-variable variableName="balanceRefined" value="#[regex('\\d+\\.\\d+'.toString(), flowVars.balanceUnrefined)]" doc:name="balanceRefined"/>
    <logger message="#[flowVars.balanceRefined]" level="INFO" doc:name="Logger"/>

最后一个记录器的结果表示为空。我做得不对劲?它是正则表达式吗?

2 个答案:

答案 0 :(得分:1)

在我们的讨论之后:

也可以使用scan功能。它会返回List<String>,因此您必须先取第一个。它适用于你的dw 2.0上的正则表达式,所以应该在de 1.0中。

我的骡子4 mule-config.xml

<ee:set-variable variableName="balance"> <![CDATA[ %dw 2.0 output application/json --- scan(vars.regexpVar, /\d+\.\d+/)[0] ]]> </ee:set-variable> </ee:variables> </ee:transform> <logger doc:id="b458c5f0-5360-40f4-b68c-b5cf1e48da51" doc:name="Logger" doc:timestamp="1518874066833" message="#[vars.balance]"/>

这是我的结果日志:

enter image description here

答案 1 :(得分:1)

我必须使用变压器来使用@shadowsheep推荐的扫描功能,并且相信他能够做到这一点。这适用于Mule 3.9并使用dataweave 1.0

<set-variable variableName="balanceUnrefined" value="#[json:balance]" doc:name="balanceUnrefined"/>
        <set-payload value="#[flowVars.balanceUnrefined]" doc:name="Set Payload"/>
        <logger message="#[payload]" level="INFO" doc:name="Logger"/>
        <dw:transform-message doc:name="Transform Message">
            <dw:set-payload><![CDATA[%dw 1.0
%output application/json
---
{
	"balance": payload scan /\d+\.\d+/
}
]]></dw:set-payload>
        </dw:transform-message>
        <logger message="#[payload]" level="INFO" doc:name="Logger"/>