检查 Json 数组是不是包含逻辑应用程序中的对象

Posted

技术标签:

【中文标题】检查 Json 数组是不是包含逻辑应用程序中的对象【英文标题】:Check if Json Array contains objects in Logic App检查 Json 数组是否包含逻辑应用程序中的对象 【发布时间】:2018-05-25 09:03:46 【问题描述】:

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

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

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

但我无法让它工作。

如果它包含成员,则为 true。

但如果不是我得到一个错误:

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

【问题讨论】:

【参考方案1】:

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

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

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

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

【讨论】:

【参考方案2】:

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

这行得通:

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

希望对某人有所帮助。

【讨论】:

以上是关于检查 Json 数组是不是包含逻辑应用程序中的对象的主要内容,如果未能解决你的问题,请参考以下文章

在 Oracle PL/SQL 中,如何检查 JSON 对象是不是包含特定键的元素

如何检查 json 对象是不是包含 <null>?

使用Javascript检查JSON对象是不是包含值[重复]

要检查数组是不是仅包含另一个数组中的元素,VB.NET

检查对象数组是不是包含数组中的任何对象

检查 JSON 文件中是不是存在数组 - iOS