How to convert from DynamoDB wire protocol to native Python object manually with boto3?

后端 未结 2 775
灰色年华
灰色年华 2021-02-08 15:36

I have a Lambda that is being triggered by a DynamoDB stream. The Lambda does some processing and then creates a notification on a topic in SNS. Ideally I would like to includ

2条回答
  •  一个人的身影
    2021-02-08 16:07

    I have a similar situation and I used the following an approach like this:

    from boto3.dynamodb.types import TypeDeserializer
    
    deser = TypeDeserializer()
    
    ...
    
        for record in event['Records']:
            old = record['dynamodb'].get('OldImage')
            new = record['dynamodb'].get('NewImage')
            if old:
                d = {}
                for key in old:
                    d[key] = deser.deserialize(old[key])
    

    This approach works for me. The resulting dictionary d contains the converted object rather than the wire-format version passed to the handler.

提交回复
热议问题