首页 > 解决方案 > 在 Lambda 中使用 Python 创建新文件、写入文件并上传到 S3

问题描述

我正在尝试在 AWS Lambda 中使用 Python 创建一个新文件并写入它,然后上传到 S3 存储桶。我希望每个文件名都基于一个变量是唯一的。在这种情况下,它是submission_id。

import json
import sys
import logging
import boto3

client = boto3.client('s3')

解析来自 webhook API 调用的数据(一切正常)

def lambda_handler(event, context):
     form_data = json.loads(event['body'])
     form_id = (form_data['FormID'])
     submission_id = (form_data['UniqueID'])

使用结果创建新文件并上传到 S3。

想要使用 submit_id 作为文件名变量。

     data_file = open('/tmp/submission_id' + '.txt', 'w+')
     data_file.write(str(form_data))
     data_file.close()

将文件上传到 S3 存储桶

     client.upload_file('/tmp/submission_id', 'mb-sentiment' , 'data_file')

我收到的错误如下。

[错误] FileNotFoundError:[Errno 2] 没有这样的文件或目录:'/tmp/submission_id' Traceback(最近一次调用):文件“/var/task/lambda_function.py”,第 24 行,在 lambda_handler client.upload_file( '/tmp/submission_id', 'mb-sentiment' , 'data_file')

有人知道我如何准确地编码吗?这似乎没有什么困难,但我是一个新手。检查了其他一些帖子,但似乎都没有解决这个特定的用例。

谢谢!

标签: pythonamazon-web-servicesamazon-s3aws-lambdaupload

解决方案


在我看来,你应该.txt在最后:

client.upload_file('/tmp/submission_id.txt', 'mb-sentiment' , 'data_file')

推荐阅读