您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

我们可以使用boto3 Python在aws s3存储桶之间递归地复制文件和文件夹吗?

我们可以使用boto3 Python在aws s3存储桶之间递归地复制文件和文件夹吗?

S3存储对象,它不存储文件夹,即使’/’或’'是对象键名的一部分。您只需要操纵键名并复制数据即可。

import boto3
old_bucket_name = 'SRC'
old_prefix = 'A/B/C/'
new_bucket_name = 'TGT'
new_prefix = 'L/M/N/'
s3 = boto3.resource('s3')
old_bucket = s3.Bucket(old_bucket_name)
new_bucket = s3.Bucket(new_bucket_name)

for obj in old_bucket.objects.filter(Prefix=old_prefix):
    old_source = { 'Bucket': old_bucket_name,
                   'Key': obj.key}
    # replace the prefix
    new_key = obj.key.replace(old_prefix, new_prefix, 1)
    new_obj = new_bucket.Object(new_key)
    new_obj.copy(old_source)

new_keyzvikico建议的优化定义技术:

new_key = new_prefix + obj.key[len(old_prefix):]
python 2022/1/1 18:38:21 有249人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶