/cos-python3-sdk

腾讯云对象存储服务(cos)Python3.5版本SDK

Primary LanguagePythonApache License 2.0Apache-2.0

cos-python3-sdk

腾讯云对象存储服务(cos)Python3.5版本SDK

*此版本非官方版本

项目进展:全部完成
项目的来由:做基于Django个人网站时,采用了腾讯云的对象存储服务,当时发现他们并没有提供基于py3的sdk,然后就有了这个项目,另外此项目SDK已多次在我的其他项目中集成,使用较稳定,可放心使用。
平台兼容性:本SDK可在Py3.4-Py3.7上使用
版本兼容性:0.1版本与0.2以上版本在变量命名上有细微差异,请谨慎升级

SDK用法简介

1.安装(下面两种方式任选其一即可)

1.1 推荐使用pip安装,命令: pip install cos-lib3

1.2 下载源码,使用setup.py安装

2.bucket操作

2.1 得到一个bucket

调用格式:

from cos_lib3.cos import Cos

cos = Cos(app_id=<appid>, secret_id='<secret_id>', secret_key='<secret_key>', region='<地域:sh(华东),gz(华南),tj(华北)>')
bucket = cos.get_bucket("<bucket名称>")

样例调用:

from cos_lib3.cos import Cos
cos = Cos(app_id=123456789, secret_id='AKIDpTgPyrRUh6cS77PTGVtHZKklTBCurQq2', secret_key='2o5eXbkgNxJ2jWnZ67z1vlIVDxfAQ', region='tj')
bucket = cos.get_bucket("test")

3.目录操作

3.1 创建目录

格式如下:

bucket.create_folder('<目录名称>')

3.2 查询目录属性

格式如下:

bucket.query_folder('<目录名称>')

3.3 列出目录

调用格式1:

rst = bucket.list_folder(dir_name='<目录名称>')
print(rst)

调用格式2(查询某个目录下特定的特定前缀的文件):

rst = bucket.list_folder(dir_name='<目录名称>', prefix='<前缀>')
print(rst)

调用格式3(查询某个目录下的文件,并限定查询数量):

rst = bucket.list_folder(dir_name='<目录名称>',  num=<查询的数量>)
print(rst)

调用格式4(综合格式2,3)

rst = bucket.list_folder(dir_name='<目录名称>', prefix='<前缀>',  num=<查询数量>)

3.4 删除目录

调用格式

rst = bucket.delete_folder('<目录名称>')
print(rst)

4 文件操作

4.1 简单文件上传(适合上传的文件的大小小于20MB)

调用格式1(文件上传到bucket的根目录):

bucket.upload_file(real_file_path='<文件的在本地的路径>', file_name='<文件在bucket的名称>')

调用格式2(文件上传到bucket的特定的目录)

bucket.upload_file(real_file_path='<文件的在本地的路径>', file_name='<文件在bucket的名称>', dir_name='<目录名称>')

4.2 文件分片上传

bucket.upload_slice_file(real_file_path='<文件的在本地的路径>',slice_size=1048576,file_name='<文件在bucket的名称>')

样例调用

real_file_path = (r'C:\Users\ZhangPeng\Desktop\01.zip')
# slice_size为分片大小,单位为Byte,有效值:1048576(1MB),如非必要,请勿修改!!
slice_size = 1048576
# file_name为文件在bucket中存储的名称
file_name = '01.zip'
bucket.upload_slice_file(real_file_path, slice_size, file_name)

4.3 文件移动

调用格式

bucket.move_file(source_fileid='<源文件的路径>', dest_fileid='目标文件的路径')

4.4 文件复制

调用格式

bucket.copy_file(source_fileid='<源文件路径>', dest_fileid='目标文件路径')

4.5 文件删除

调用格式

bucket.delete_file('<文件的绝对路径>')

4.6 通过url上传文件

调用格式如下:

bucket.upload_file_from_url("http://sucai.qqjay.com/qqjayxiaowo/201210/26/1.jpg", file_name="777.jpg", dir_name=None)

第一个参数为文件的url地址,
第二个参数为放在云存储上的显示的文件的文件名,
第三个参数为文件在云存储上的文件目录,可以为None,此时放在根目录上

5.附录

5.1 上传文件后我该怎么获取用于访问的链接?

首先获取上传之后的返回值 如:data = bucket.upload_file(real_file_path='<文件的在本地的路径>', file_name='<文件在bucket的名称>')
得到的data 的值形如:
{'source_url': 'http://test-125255866665.costj.myqcloud.com/777.jpg', 'access_url': 'http://test-125255866665.file.myqcloud.com/777.jpg', 'url': 'http://tj.file.myqcloud.com/files/v2/125255866665/test/777.jpg', 'vid': '8fea559ee6578acf89698bef7ae5b6551494676054', 'resource_path': '/125255866665/test/777.jpg'}
下面我们来解析这个data字符串,得到access_url字段的值并输出:

access_url = eval(data).get("access_url")
print(access_url)

5.2 如果我需要https形式的链接怎么办?

腾讯云的对象存储服务完全是支持https的,如果你获取到的链接并不是https形式的,尝试使用replace函数把‘http://’ 直接替换成 ‘https://’ 试试

#### 5.3 分片上传现在是无法使用吗? 感谢开源社区的热心成员,他们提供了分片上传的代码,现在已经集成进去了此sdk,由于本人忙于其他的项目,未能做详尽的测试,分片上传的方法名为 ``` upload_slice_file() ``` 如果这个方法没办法满足您的需求,请尝试 https://github.com/a270443177/cos-python3-sdk-v4 这个类库的使用方法完全同于腾讯云对象存储的py2.7版本的SDK

5.3 分片上传现在是无法使用吗?

感谢开源社区的热心成员,他们提供了分片上传的代码,经过测试,可以放心使用!

5.4 您发现了bug,或者有什么其他的需求和建议

请报告issue

5.5 出现 You do not have permission to get URL '*' from this server.

初始化 cos时:
正确填写region参数,在 COS 控制台 => bucket列表 => 基础配置=>所属地区
如 北京 (bj), region='bj'
以下表格摘自官网文档于(2018-04-13)

地域 地域简称 默认下载域名 上传域名
北京一区(华北) tj <bucketname-APPID>.costj.myqcloud.com tj.file.myqcloud.com
北京 bj <bucketname-APPID>.cosbj.myqcloud.com bj.file.myqcloud.com
上海(华东) sh <bucketname-APPID>.cossh.myqcloud.com sh.file.myqcloud.com
广州(华南) gz <bucketname-APPID>.cosgz.myqcloud.com gz.file.myqcloud.com
成都(西南) cd <bucketname-APPID>.coscd.myqcloud.com cd.file.myqcloud.com
新加坡 sgp <bucketname-APPID>.cossgp.myqcloud.com sgp.file.myqcloud.com
香港 hk <bucketname-APPID>.coshk.myqcloud.com hk.file.myqcloud.com
多伦多 ca <bucketname-APPID>.cosca.myqcloud.com ca.file.myqcloud.com
法兰克福 ger <bucketname-APPID>.cosger.myqcloud.com ger.file.myqcloud.com

5.6 upload_file 返回值为None

如果代码配置没有错误,检查下电脑的时间是不是对的

6.致谢(排名不分先后)

在本项目的发展过程中得到了来自开源社区的很多成员的宝贵意见以及无私帮助,为这个项目发展做出的极大的贡献,
特别是以下用户:
fushall1104:帮助修复命名上的一处bug
a270443177:提供分片上传的代码
zhangpengpengpeng:帮助测试分片上传功能
xfdywy:提出一个配置region可能遇到的问题

7.授权协议

本项目遵循Apache协议,完全开源,文档齐全,永远免费(商用也是)