我已获得对 S3 存储桶的子文件夹的访问权限,并想使用 Python 和 boto3 访问其中的所有文件。我是 S3 的新手并且已经阅读了所有文档,但无法弄清楚如何仅成功访问一个子文件夹。我知道 s3 不使用类似 unix 的目录结构,但我无权访问根存储桶。
如何将 boto3 配置为仅连接到此子文件夹?
我已成功使用此 AWS CLI 命令将整个子文件夹下载到我的机器上:
aws s3 cp --recursive s3://s3-bucket-name/SUB_FOLDER/ /Local/Path/Where/Files/Download/To --profile my-profile
此代码:
AWS_BUCKET='s3-bucket-name'
s3 = boto3.client("s3", region_name='us-east-1', aws_access_key_id=AWS_KEY_ID, aws_secret_access_key=AWS_SECRET)
response = s3.list_objects(Bucket=AWS_BUCKET)
返回此错误:
botocore.exceptions.ClientError: An error occurred (AccessDenied) when calling the ListObjects operation: Access Denied
我还尝试在调用 list_objects 时指定“前缀”选项,但这会产生相同的错误。
答案 0 :(得分:0)
您想aws configure
并保存您的凭据和区域,然后使用 boto3 既简单又容易。
使用 boto3.resource 并像这样获取客户端:
s3_resource = boto3.resource('s3')
s3_client = s3_resource.meta.client
s3_client.list_objects(Bucket=AWS_BUCKET)
你应该没事了。