我在 Apply To each 中执行多个 API 调用,以便从同一外部 API 获取不同日期/时间的数据。然后我执行以下操作:-
- 从 API 调用响应中删除 SOAPTAgs
- 将结果转换为 XML
- 将 XML 转换为 JSON
- 解析 JSON
- 过滤 JSON
- 循环遍历 FilterJSON-IncludeUser 的结果并将项目附加到名为“jointJson”的数组中
以上是就功能而言的工作,我将从“JointJson”数组内的所有 API 调用中获取所有 JSON。但这需要时间,主要是在“应用于每个 3”上,我正在构建“JointJson”数组 + 工作流消耗了许多操作,超出了我可以拥有的阈值限制,即每 24 小时 48,000 次调用。
所以我的问题是,有没有办法将 FilterJSON-IncludeUser 操作的结果加入到 ApplyToEach 中,而不必循环遍历结果并使用 ApendToArray?
“FilterJSON-IncludeUser”的结果如下:-
{"body":[{"@Id":"19267384","@AgentId":"11**","@CallDuration":"0:00:49","@CallOrigin":"Outbound - Manual","@CallSegment":"Initial","@CallTime":"12/2/2024 5:51:30 AM","@Campaign":"Affiliate","@ContactId":"42***74","@Group":"Openers","@InboundPhone":"","@LeadFullName":"Dj*** T***","@LeadId":"42***","@ProspectPhone":"+1***","@RecordingUrl":"","@Result":"Conversation","@TargetNumber":"+1 5***","@User":"****","@WaitTime":"","@CallId":"2****"},{"@Id":"19267387","@AgentId":"11657","@CallDuration":"0:00:35","@CallOrigin":"Outbound - Manual","@CallSegment":"Initial","@CallTime":"12/2/2024 5:52:54 AM","@Campaign":"Affiliate","@ContactId":"428***","@Group":"Openers","@InboundPhone":"","@LeadFullName":"**","@LeadId":"4286***","@ProspectPhone":"+*****","@RecordingUrl":"","@Result":"Conversation","@TargetNumber":"+1 ***","@User":"****","@WaitTime":"","@CallId":"C***7"}]}
否则它将是空的。
有什么建议吗?
谢谢
这看起来太简单了,但是Union函数可以帮助您。
https://learn.microsoft.com/en-us/azure/logic-apps/workflow-definition-language-functions-reference#union
但是,请注意...它会删除重复项,它只存储唯一的项目,所以如果确实发生某种重复的事情,那可能是你的失败。
您需要
Compose
先将数组组合在一起,然后使用步骤输出中的Set variable
值进行设置。我相信您已经知道在变量设置中不能进行自我引用。JointJson
Compose