我正在尝试从S3存储桶中读取文件内容(而不是下载它)。问题是该文件位于多级文件夹下。例如,完整路径可以是s3://s3-bucket/folder-1/folder-2/my_file.json。我如何才能获得特定的文件,而不是使用列出所有对象的迭代方法?
下面是我想要更改的代码:
import boto3
s3 = boto3.resource('s3')
bucket = s3.Bucket('s3-bucket')
for obj in my_bucket.objects.all():
key = obj.key
if key == 'folder-1/folder-2/my_file.json':
return obj.get()['Body'].read()可以用一种更简单、更直接的方式来完成吗?
发布于 2021-11-08 11:00:38
是-不需要枚举存储桶。
使用s3.Object直接读取文件,将存储桶名作为第一个参数,将对象键作为第二个参数。
“文件夹”并不真正存在于亚马逊中--亚马逊S3并不使用层次结构来组织其对象和文件。为了简化组织,亚马逊S3控制台将“文件夹”显示为一种对对象进行分组的方法,但它们最终会被放入您的对象键中。
这应该是可行的:
import boto3
s3 = boto3.resource('s3')
obj = s3.Object("s3-bucket", "folder-1/folder-2/my_file.json")
body = obj.get()['Body'].read()https://stackoverflow.com/questions/69882380
复制相似问题