检查 Json Array 是否包含 Logic App 中的对象

问题描述 投票:0回答:2

我正在尝试这个,但我似乎无法让它发挥作用。

在条件连接器中我正在这样做:

@contains(json(body('ParseCustomerDeltaXML')).newMembers[0], 'Member')

但我无法让它工作。

如果它包含成员,则表示为真。

但如果没有,我会收到错误:

模板无效。无法处理第“1”行和“2706”列处的操作“条件”的模板语言表达式:“模板语言表达式 'equals(json(body('ParseCustomerDeltaXML')).newMembers[0], null)' 不能评估,因为无法从空数组中选择数组索引“0”。请参阅https://aka.ms/logicexpresss了解使用详细信息。'。

arrays json conditional-statements contains azure-logic-apps
2个回答
0
投票

如错误消息所示,您尝试引用的第一项的数组为空。您想使用安全解引用运算符

.?

假设

newMembers
是一个空数组。那么
newMembers[0]
会失败,但
newMembers?[0]
会成功(并返回
null
)。

在您描述的具体场景中,您可能还需要使用嵌套条件(即首先检查 newMembers 是否非空,然后检查成员资格)。

要检查是否为空,您可以使用

@empty()
表达式。


0
投票

在我的示例中,我应该在从元素获取街道数据之前检查元素是否为空。

这有效:

if(empty(body('Parse_JSON')?['results'][0]['addresses']), '', body('Parse_JSON')?['results'][0]['addresses'][0]['street'])

这也有效:

if(contains(['addresses'], ['addresses']?[0]), 'Do something', 'Or do this thing')

希望对某人有帮助。

© www.soinside.com 2019 - 2024. All rights reserved.