Ich habe den Funktionscode folgende Lambda für einfach den Autor und Metadaten eines hochgeladen Falle eines S3-Bucket Ausdrucken:"KeyError: 'Records'" in AWS S3 - Lambda-Trigger
from __future__ import print_function
import json
import urllib
import boto3
print('Loading function')
s3 = boto3.client('s3')
def lambda_handler(event, context):
#print("Received event: " + json.dumps(event, indent=2))
# bucket = event['Records'][0]['s3']['bucket']['name']
for record in event['Records']:
bucket = record[0]['s3']['bucket']['name']
key = record[0]['s3']['object']['key']
response = s3.head_object(Bucket=bucket, Key=key)
logger.info('Response: {}'.format(response))
print("Author : " + response['Metadata']['author'])
print("Description : " + response['Metadata']['description'])
aber ich, ich erhalte die folgende Fehlermeldung während des Tests:
{
"stackTrace": [
[
"/var/task/lambda_function.py",
17,
"lambda_handler",
"for record in event['Records']:"
]
],
"errorType": "KeyError",
"errorMessage": "'Records'"
}
bin ich falsch etwas zu tun, während der Eimer Namen und Schlüsselnamen des Objekts S3 zugreifen? Wenn nicht, was mache ich dann falsch?
Welche Art von S3-Ereignis Trigger verwenden Sie? – franklinsijo
@franklinsijo 'Ereignistyp: ObjectCreated' – Dawny33
Und ist dies ein Test-Event oder ein tatsächliches Event? Können Sie das 'Ereignis' ausdrucken und prüfen, ob es' Records' enthält? – franklinsijo