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

时间:2017-12-11 19:09:42

标签: arrays json conditional-statements contains azure-logic-apps

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

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

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

但是我无法让它发挥作用。

如果它包含成员则说明是真的。

但如果不是我收到错误:

  

InvalidTemplate。无法处理模板语言表达式以执行操作'条件'在线' 1'和列' 2706':'模板语言表达式'等于(json(正文(' ParseCustomerDeltaXML'))。newMembers [0],null)&#39 ;无法评估,因为数组索引' 0'无法从空数组中选择。有关使用详情,请参阅https://aka.ms/logicexpressions。'。

2 个答案:

答案 0 :(得分:0)

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

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

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

要检查空虚,您可以使用@empty()表达式。

答案 1 :(得分:-1)

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

这有效:

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')

希望对别人有帮助。