python - 是否可以在调用 lamda 函数中使用组聚合?
问题描述
我创建了三个 lambda 函数 1).postData 2).like 3).comment。我正在使用调用 lambda 函数来组合三个输出。找到以下代码供您参考。
lambdas = boto3.client("lambda")
def lambda_handler(event, context):
print("Received event: " + json.dumps(event, indent=1))
response1 = lambdas.invoke(FunctionName="postdata",
InvocationType="RequestResponse", Payload=json.dumps(event,
default=json_util.default));
response2 = lambdas.invoke(FunctionName="like",
InvocationType="RequestResponse", Payload=json.dumps(event,
default=json_util.default));
response3 = lambdas.invoke(FunctionName="comment",
InvocationType="RequestResponse", Payload=json.dumps(event,
default=json_util.default));
result1 = json.loads(response1.get('Payload').read())
result2 = json.loads(response2.get('Payload').read())
result3 = json.loads(response3.get('Payload').read())
return result1+result2+result3
在这里,我在一个数组中得到了三个 lambda 函数。在三个 lambda 函数中,我们有一个唯一的 id,但有三个不同的文件名。如下所示
[
{
"_id": {
"$oid": "5d6fbc4256cfe9fcfd8c4136"
},
"location": null,
"media_type": "jpg",
},
{
"_id": {
"$oid": "5d5dd01d93ab7d1ed7e2ff31"
},
"location": null,
"media_type": "jpg",
},
{
"from": {
"$oid": "5d5dcccf9cf5ce000183d15e"
},
"to": {
"$oid": "5d5dd01d93ab7d1ed7e2ff31"
},
"interaction_type": "feelings",
},
{
"from": {
"$oid": "5d5dcccf9cf5ce000183d15e"
},
"to": {
"$oid": "5d6fbc4256cfe9fcfd8c4136"
},
"interaction_type": "feelings",
},
{
"from": {
"$oid": "5d5dcccf9cf5ce000183d15e"
},
"to": {
"$oid": "5d5dd01d93ab7d1ed7e2ff31"
},
"interaction_data": "nice car.....",
},
{
"from": {
"$oid": "5d5dcccf9cf5ce000183d15e"
},
"to": {
"$oid": "5d5dd01d93ab7d1ed7e2ff31"
},
"interaction_data": "awesome car.....",
},
{
"from": {
"$oid": "5d5dcccf9cf5ce000183d15e"
},
"to": {
"$oid": "5d6fbc4256cfe9fcfd8c4136"
},
"interaction_data": "Hello world....",
}
]
我用粗体大括号 getpost 划分了输出,例如评论输出。我关心的是 getpost -“_id”,比如 - “to”,comment - “to” 字段值是唯一的。基于这个唯一值,我可以对输出进行分组吗?意味着我需要 _id 来提交相同的值,这些值将显示在一个数组中。可能吗?
提前致谢。
解决方案
您在这里有两个选择。
创建一个将运行所有三个查询的 lambda,并在那里聚合(下面的 mongo 分组示例)。
解析您的 JSON 响应对象(如果它们尚未被解析)并手动聚合。
显然#1 会更高效,也更优雅。
Mongo聚合/分组函数示例:
db.sales.aggregate(
[
{
$group : {
_id : { month: { $month: "$date" }, day: { $dayOfMonth: "$date" }, year: { $year: "$date" } },
totalPrice: { $sum: { $multiply: [ "$price", "$quantity" ] } },
averageQuantity: { $avg: "$quantity" },
count: { $sum: 1 }
}
}
]
)
如果您决定在 lambda 中使用 mongo 分组路线,请记住它在计算时会在内存存储中使用。如果你的数据集很大,这会给你一个错误。如果您遇到该问题allowDiskUse
,请按照文档的建议设置为 true。
看:
推荐阅读
- ios - 是否可以在 Apple Watch Series 6 上通过您自己的应用程序查询血氧饱和度传感器?
- julia - 如何在 Julia 中创建文件?
- elasticsearch - 弹性搜索排除通配符查询异常
- questdb - QuestDB(嵌入式)TableWriter 线程安全吗?
- angular - Dotnet 核心角度 cookie 身份验证
- powershell - 高效解析键值数据
- spring-boot - 如何在运行时使用 Spring Boot 更改数据源
- xml - 使用 XSLT 显示来自 XSD 的选项和来自 XML 的默认值
- python - 使用来自另一个函数的列表会将其传递为空,为什么?
- javascript - 启用右键单击文本编辑器