python对AWS—S3【存储桶】的下载,上传,追加操作

小猪肥

关注

阅读 48

2022-03-22

完整的代码如下:

#!/usr/bin/env python3.8
# -*- coding: utf-8 -*-
# @Time    : 2022/1/20 17:15
# @Author  : luoxuan
# @File    : test.py
import os
import s3fs
from setting import *
from boto3.session import Session
from botocore.exceptions import ClientError


class Operation_aws_s3():
    def __init__(self):
        url = "https://{}".format(FORMAL_S3_CONFIG['s3_endpoint'])  # 也可以是自己节点的地址
        session = Session(FORMAL_S3_CONFIG['access_key'], FORMAL_S3_CONFIG['secret_key'])
        self.s3_client = session.client('s3', endpoint_url=url)

    def download_file(self, objectName, fileName):
        """
        下载文件
        :param objectName: 文件的路径
        :param fileName: 下载完成的文件的名称----注意:下载之后的文件默认储存在自己的python工程路径下
        :return:
        """
        self.s3_client.download_file(FORMAL_S3_CONFIG['bucket'], objectName, fileName)

    def upload_file(self, file_name, object_name):
        """
        上传文件
        :param file_name: 需要上传的文件的名称
        :param object_name: 需要上传到的路径,例如file/localfile/test
        :return:
        """
        if object_name is None:
            object_name = file_name
        try:
            self.s3_client.upload_file(file_name, FORMAL_S3_CONFIG['bucket'], object_name)
            print('文件推送至s3成功')
        except ClientError as e:
            print('aws_s3文件上传出错{}'.format(e))
            return False
        return True

    def list_object(self, dir_path):
        """
        列出当前桶下所有的文件
        :param dir_path: 查询包含指定文件夹的文件和文件大小
        :return:
        """
        file_list = []
        response = self.s3_client.list_objects_v2(
            Bucket=FORMAL_S3_CONFIG['bucket'],
            # MaxKeys=1000  # 返回数量,如果为空则为全部
        )
        file_desc = response['Contents']
        for f in file_desc:
            if dir_path:
                if dir_path in f['Key']:
                    file_list.append({'path': f['Key'], 'path_size': f['Size']})
                else:
                    pass
            else:
                file_list.append({'path': f['Key'], 'path_size': f['Size']})
        return file_list

    def add_file(self, data_list, filepath, mode):
        '''
        往S3上的文件写入数据
        :param data_list: 追加的数据【数据必须是字符串类型】
        :param filepath: 数据追加到的文件【需要包含路径】
        :param mode: 往文件写入时的写入模式
        :return:
        '''
        bytes_to_write = data_list.encode()
        # print(bytes_to_write)
        try:
            fs = s3fs.S3FileSystem(client_kwargs={'endpoint_url': 'https://{}'.format(FORMAL_S3_CONFIG['s3_endpoint'])},
                                   key=FORMAL_S3_CONFIG['access_key'], secret=FORMAL_S3_CONFIG['secret_key'])
            with fs.open('s3://{}/{}'.format(FORMAL_S3_CONFIG['bucket'], filepath), str(mode)) as f:
                f.write(bytes_to_write)
            content = '往》{}《文件中写入数据成功'.format(filepath)
        except Exception as e:
            # print(e)
            content = '往》{}《文件中写入数据出错》》{}'.format(filepath, e)
        return content


if __name__ == '__main__':
    t = Operation_aws_s3()
    xian_path1 = r'captain-keyword/test.txt'
    ben_path1 = os.path.join(os.getcwd(), 'b1.txt').replace('\\', '/')
    xian_path2 = r"captain-keyword/1/2022/1_2022_1642559812b'172.18.0.4result.txt"
    ben_path2 = r'./test.txt'
    # 上传文件
    t.upload_file(ben_path1, xian_path1)
    # 下载文件
    t.download_file(xian_path2, ben_path2)
    # 往指定文件追加数据
    for i in range(10):
        data_list = '1234567821'
        filepath = 'captain-keyword/1/2022/1_2022_1641348991_result.txt'
        mode = 'ab'
        t.add_file(data_list, filepath, mode)

seting文件配置如下:

FORMAL_S3_CONFIG = {
    'access_key': '*****',
    'secret_key': '****',
    'region_name': '****',
    'bucket': '存储桶的名字',  # aws s3存储桶
    's3_endpoint': '链接地址',
    'filie_path': '线上的文件路径',  # 线上文件夹(用来存放当前项目的文件)
    'file_size': 104857600  # 线上单个文件的大小(单位为字节)
}

精彩评论(0)

0 0 举报