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

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

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

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

import boto3old_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_key
zvikico建议的优化定义技术:

new_key = new_prefix + obj.key[len(old_prefix):]


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5645475.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存