首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将亚马逊网络服务DynamoDB数据转换为json格式

将亚马逊网络服务DynamoDB数据转换为json格式
EN

Stack Overflow用户
提问于 2020-11-22 16:49:41
回答 1查看 995关注 0票数 0

我有一个DynamoDB表,它需要转换为json格式,并使用Python/Boto3/AWS-Lambda环境在API响应中共享。

代码语言:javascript
复制
userMetrics[
{
  "userid": 1234567890,  ==> key
  "likemetrics": 0,
  "lasttimestamp": 1604553995
},
{
  "userid": 1234567891,  ==> key
  "likemetrics": 0,
  "lasttimestamp": 1604553998
}]

我尝试使用Formatting DynamoDB data to normal JSON in AWS Lambda中提到的示例将整个DynamoDB表复制为json格式,但在执行时遇到错误

代码语言:javascript
复制
{
"errorMessage": "'dynamodb.Table' object has no attribute 'items'",
"errorType": "AttributeError",
"stackTrace":[
"  File \"/var/task/lambda_function.py\", line 75, in lambda_handler\n    'usermetrics': json.dumps(from_dynamodb_to_json(dydb_userTable))\n",
"  File \"/var/task/lambda_function.py\", line 7, in from_dynamodb_to_json\n    return {k: d.deserialize(value=v) for k, v in item.items()}\n"
]
}

我的lambda代码实现:

代码语言:javascript
复制
import json
import boto3
from boto3.dynamodb.types import TypeDeserializer, TypeSerializer

def from_dynamodb_to_json(item):
    d = TypeDeserializer()
    return {k: d.deserialize(value=v) for k, v in item.items()}

dydb = boto3.resource('dynamodb')
dydb_userTable = dydb.Table('userMetrics')

def lambda_handler(event, context):
        return {
            'statusCode': 200,
            'usermetrics': json.dumps(from_dynamodb_to_json(dydb_userTable))
        }
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-11-22 18:39:25

Table (代码中的dydb_userTable)对象没有您要查找的items。您需要在该表上调用一个将为您检索项的方法,例如dydb_userTable.scan()dydb_userTable.query()

参考:https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/dynamodb.html#table

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64952204

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档