我试图从S3存储桶中的子文件夹中的多个文件创建一个zipfile,然后将该zipfile保存在同一存储桶中的另一个子文件夹中
在本地运行flask应用程序时,我可以从S3子文件夹bucket创建ZipFile,但不能使用Heroku,因为它不存储任何内容
我正在看这个例子,但它似乎过时了,并且使用了本地文件。 https://www.botreetechnologies.com/blog/create-and-download-zip-file-in-django-via-amazon-s3
下面是我正在使用的代码片段
from flask import Response
import boto3, zipfile, os
AWS_ACCESS_KEY_ID = "some access key"
AWS_ACCESS_SECRET_ACCESS_KEY = "some secret key"
AWS_STORAGE_BUCKET_NAME = "some bucket"
aws_session = boto3.Session(aws_access_key_id = AWS_ACCESS_KEY_ID,
aws_secret_access_key = AWS_SECRET_ACCESS_KEY)
s3 = aws_session.resource("s3")
s3 = boto3.client("s3", region_name = "some region")
s3_resource = boto3.resource("s3")
blog_folder = "blog_1"
paginator = s3.get_paginator("list_objects")
file_list = [page for page in paginator.paginate(Bucket=AWS_STORAGE_BUCKET_NAME)\
.search("Contents[?Size >`0`][]")
if blog_folder in page["Key"]]
zf = zipfile.ZipFile(byte, "w")
zipped_files = []
zip_filename = "download_files.zip"
for key in file_list:
file_name = key["Key"].split("/")[-1]
my_bucket = s3_resource.Bucket(AWS_STORAGE_BUCKET_NAME)
file_obj = my_bucket.Object(key["Key"]).get()
zipped_files.append(file_obj["Body"].read())
你知道我怎么解决这个问题吗?用户下载zipfile比下载单个文件方便得多。 非常感谢您的帮助
python的内存zip库非常适合于此。下面是我的一个项目中的一个示例:
所以我设法让它在我的Heroku flask应用程序中工作。 希望它能帮助任何挣扎的人。 PS子文件夹=博客文件夹 所以结构是Bucket/blog\u文件夹/resources Bucket/blog_文件夹/压缩
相关问题 更多 >
编程相关推荐