AWS Python Lambda函数-将文件上传到S3

pol*_*guy 7 amazon-s3 python-2.7 aws-lambda

我有一个用Python 2.7编写的AWS Lambda函数,我想在其中执行以下操作:

1)从HTTP地址获取一个.xls文件。

2)将其存放在临时位置。

3)将文件存储在S3存储桶中。

我的代码如下:

from __future__ import print_function
import urllib
import datetime 
import boto3
from botocore.client import Config

def lambda_handler(event, context):

    """Make a variable containing the date format based on YYYYYMMDD"""
    cur_dt = datetime.datetime.today().strftime('%Y%m%d')

    """Make a variable containing the url and current date based on the variable
    cur_dt"""
    dls = "http://11.11.111.111/XL/" + cur_dt + ".xlsx"
    urllib.urlretrieve(dls, cur_dt + "test.xls")

    ACCESS_KEY_ID = 'Abcdefg'
    ACCESS_SECRET_KEY = 'hijklmnop+6dKeiAByFluK1R7rngF'
    BUCKET_NAME = 'my-bicket'
    FILE_NAME = cur_dt + "test.xls";

    data = open('/tmp/' + FILE_NAME, 'wb')

    # S3 Connect
    s3 = boto3.resource(
        's3',
        aws_access_key_id=ACCESS_KEY_ID,
        aws_secret_access_key=ACCESS_SECRET_KEY,
        config=Config(signature_version='s3v4')
    )

    # Uploaded File
    s3.Bucket(BUCKET_NAME).put(Key=FILE_NAME, Body=data, ACL='public-read')
Run Code Online (Sandbox Code Playgroud)

但是,当我运行此函数时,出现以下错误:

“ IOError:[Errno 30]只读文件系统”

我已经花了数小时试图解决这个问题,但是我倒在脸上了。任何帮助,将不胜感激。

小智 5

“ IOError:[Errno 30]只读文件系统”

您似乎缺少一些写访问权限。如果您的lambda还有其他政策,请尝试将此政策附加到您的角色:

arn:aws:iam :: aws:policy / AWSLambdaFullAccess

如果您无法在存储桶中写入数据,它也对S3具有完全访问权限。如果它解决了您的问题,则此后您将删除一些权利。


小智 5

我已将图像上传到 s3 Bucket。在“Lambda Test Event”中,我创建了一个 json 测试事件,其中包含要上传到 s3 Bucket 的图像的 BASE64 和图像名称。Lambda 测试 JSON 事件作为休闲 ======>

            { 
                "ImageName": "Your Image Name",
                "img64":"BASE64 of Your Image"
            }
Run Code Online (Sandbox Code Playgroud)

以下是将图像或任何文件上传到 s3 的代码======>

import boto3
import base64
def lambda_handler(event, context):
    s3 = boto3.resource(u's3')
    bucket = s3.Bucket(u'YOUR-BUCKET-NAME')
    path_test = '/tmp/output'         # temp path in lambda.
    key = event['ImageName']          # assign filename to 'key' variable
    data = event['img64']             # assign base64 of an image to data variable 
    data1 = data
    img = base64.b64decode(data1)     # decode the encoded image data (base64)
    with open(path_test, 'wb') as data:
        #data.write(data1)
        data.write(img)
        bucket.upload_file(path_test, key)   # Upload image directly inside bucket
        #bucket.upload_file(path_test, 'FOLDERNAME-IN-YOUR-BUCKET /{}'.format(key))    # Upload image inside folder of your s3 bucket.
    print('res---------------->',path_test)
    print('key---------------->',key)

    return {
            'status': 'True',
       'statusCode': 200,
       'body': 'Image Uploaded'
      }
Run Code Online (Sandbox Code Playgroud)


小智 1

更改data = open('/tmp/' + FILE_NAME, 'wb')将 wb 更改为“r”

另外,我假设您的 IAM 用户具有对 S3 的完全访问权限,对吧?

或者问题可能出在该 url 的请求中...尝试 cur_dt 以“/tmp/”开头 urllib.urlretrieve(dls, "/tmp/" + cur_dt + "test.xls")