Ошибка при вставке данных JSON в DynamoDB с использованием Python - PullRequest
0 голосов
/ 24 апреля 2020
    HI,

    I am trying to put the json data into AWS dynamodb table using AWS Lambda , however i am getting an error like below. My json file is uploaded to S3 bucket.

    Parameter validation failed:
    Invalid type for parameter Item, value:
    {
        "IPList": [
            "10.1.0.36",
            "10.1.0.27"
        ],
        "TimeStamp": "2020-04-22 11:43:13",
        "IPCount": 2,
        "LoadBalancerName": "internal-ALB-1447121364.us-west-2.elb.amazonaws.com"
    }
    , type: <class 'str'>, valid types: <class 'dict'>: ParamValidationError

Below i my python script:-

    import boto3
    import json
    s3_client = boto3.client('s3')
    dynamodb = boto3.resource('dynamodb')
    def lambda_handler(event, context):
        bucket = event['Records'][0]['s3']['bucket']['name']
        json_file_name = event['Records'][0]['s3']['object']['key']
        json_object = s3_client.get_object(Bucket=bucket,Key=json_file_name)
        jsonFileReader = json_object['Body'].read()
        jsonDict = json.loads(jsonFileReader)
        table = dynamodb.Table('test')
        table.put_item(Item=jsonDict)

        return 'Hello'

Ниже мое json содержимое

"{\" IPList \ ": [\" 10.1.0.36 \ ", \" 10.1.0.27 \ "], \" TimeStamp \ " : \ "2020-04-22 11: 43: 13 \", \ "IPCount \": 2, \ "LoadBalancerName \": \ "internal-ALB-1447121364.us-west-2.elb.amazon aws .com \ "}"

Может кто-нибудь помочь мне, как можно вставить данные в DynamodB.

1 Ответ

0 голосов
/ 24 апреля 2020

json.loads(jsonFileReader) возвращает string, но table.put_item() ожидает dict. Вместо этого используйте json.load().

...