Python &引用;KeyError:';记录'&引用;在AWS S3中-Lambda触发器

Python &引用;KeyError:';记录'&引用;在AWS S3中-Lambda触发器,python,amazon-web-services,amazon-s3,aws-lambda,Python,Amazon Web Services,Amazon S3,Aws Lambda,我有以下lambda函数代码,可以简单地打印出S3 bucket上传事件的作者和元数据: 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.

我有以下lambda函数代码,可以简单地打印出S3 bucket上传事件的作者和元数据:

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'])
但是,我在测试时遇到以下错误:

{
  "stackTrace": [
    [
      "/var/task/lambda_function.py",
      17,
      "lambda_handler",
      "for record in event['Records']:"
    ]
  ],
  "errorType": "KeyError",
  "errorMessage": "'Records'"
}

在访问S3对象的bucket名称和key名称时,我是否做错了什么?如果没有,那我做错了什么?

晚会有点晚了。但这是我的第一篇帖子

说明:


当您在lambda面板->def lambda_处理程序(事件,上下文)event event event中进行测试时,我昨天遇到了这个问题,问题是当您运行测试时,实际上没有任何事件(def lambda_处理程序(事件,上下文))可供lambda处理。事件文档通常是在实际事件(json文档)发生时生成的,python代码解析该文档,然后检索键。因此,解决方案是通过在s3中删除一个文件来创建一个实际事件,只要您已经创建了事件通知,那么它就会被拾取。我也面临同样的问题,我们需要在这里做的事情非常简单。lambda的区域和创建bucket/trigger时的区域应该相同。如果相同,只需将文件上传到S3 bucket就会直接反映到DynamoDB。

您使用的S3事件触发器的类型是什么?@franklinsijo
事件类型:ObjectCreated
这是测试事件还是实际事件?。您是否可以打印
事件
并检查它是否包含
记录
?如果这是测试,您可能已配置了默认测试事件,该事件不包含
记录
键。@franklinsijo Yeah。可能就是这样。谢谢但是,CloudWatch日志向我显示了这个错误:
'key1':KeyError回溯(最近一次调用):文件/var/task/lambda_function.py”,第10行,lambda_处理程序打印(“value1=“+event['key1'])KeyError:'key1'
如果我试图在没有API调用的情况下执行lambda,我该如何解决这个问题?