Skip to main content

NetEase Object Storage SDK For Python3

Project description

NOS Python SDK
==============

NOS Python SDK实现了NOS对象操作接口,基于此SDK能方便快速地实现Python应用程序来使用NOS的对象存储服务。

支持的功能
----------

对象操作接口
^^^^^^^^^^^^

* Delete Object —— 删除一个对象
* Delete Multiple Objects —— 用一个HTTP请求删除同一个Bucket中的多个对象
* Get Object —— 读取对象内容
* Head Object —— 获取对象相关元数据信息
* List Objects —— 获取一个桶的对象列表
* Put Object —— 上传一个对象
* Put Object - Copy —— 拷贝一个对象
* Put Object - Move —— 桶内部move一个对象

大对象分块操作接口
^^^^^^^^^^^^^^^^^^

* Initiate Multipart Upload —— 初始化分块上传
* Upload Part —— 上传一个分块
* Complete Multipart Upload —— 完成分块上传
* Abort Multipart Upload —— 取消分块上传并删除已上传的分块
* List Parts —— 列出已上传的分块
* List Multipart Uploads —— 列出所有执行中的分块上传事件

接口实现
--------

在调用对象操作接口前需要生成一个nos.Client类的实例。且在调用操作接口时,都有可能抛出异常,可以使用`nos.exceptions.ServiceException`捕获nos服务器异常错误,使用`nos.exceptions.ClientException`捕获nos客户端异常错误。

nos.Client对象实例化
^^^^^^^^^^^^^^^^^^^^

使用举例

::

client = nos.Client(
access_key_id="string",
access_key_secret="string",
transport_class=nos.transport.Transport,
**kwargs
)

参数说明

* access_key_id(string) -- 访问凭证ID。当需要访问的桶属性为Public-read时,可以将该值设置成None。默认值为:None。
* access_key_secret(string) -- 访问凭证密钥。当需要访问的桶属性为Public-read时,可以将该值设置成None。默认值为:None。
* transport_class(class) -- 与NOS服务器进行数据传输的类型,类型中至少需要包含`perform_request`成员函数。默认值为:nos.transport.Transport。
* kwargs -- 其他可选参数,如下。
* end_point(string) -- 与NOS服务器进行数据传输、交互的服务器的主域名。默认为:`nos-eastchina1.126.net`。
* num_pools(integer) -- HTTP连接池的大小。默认值为:16。
* timeout(integer) -- 连接超时的时间,单位:秒。
* max_retries(integer) -- 当得到HTTP 5XX的服务器错误的响应时,进行重试的次数。默认值为:2。
* enable_ssl(boolean) -- 与NOS服务器进行数据传输、交互时,是否使用HTTPS。默认值为:False,默认使用HTTP。

nos.Client可能引发的所有异常类型
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

在程序运行过程中,如果遇到错误,Python SDK会抛出相应的异常。所有异常均属于NOSException类,其下分为两个子类:ClientException、ServiceException。在调用Python SDK接口的时候,捕捉这些异常并打印必要的信息有利于定位问题。

ClientException
:::::::::::::::

ClientException包含SDK客户端的异常。比如,上传对象时对象名为空,就会抛出该异常。
ClientException类下有如下子类,用于细分客户端异常:

.. list-table::
:widths: 5 10
:header-rows: 1

* - 类名
- 抛出异常的原因
* - InvalidBucketName
- 传入的桶名为空
* - InvalidObjectName
- 传入的对象名为空
* - FileOpenModeError
- 出入的对象为文件且没有使用二进制文件方式打开
* - XmlParseError
- 解析服务端响应的XML内容失败
* - SerializationError
- 上传对象序列化失败
* - ConnectionError
- 连接服务端异常
* - ConnectionTimeout
- 连接服务端超时

ServiceException
::::::::::::::::

ServiceException包含NOS服务器返回的异常。当NOS服务器返回4xx或5xx的HTTP错误码时,Python SDK会将NOS Server的响应转换为ServiceException。
ServiceException类下有如下子类,用于细分NOS服务器返回的异常:

.. list-table::
:widths: 5 10
:header-rows: 1

* - 类名
- 抛出异常的原因
* - MultiObjectDeleteException
- 批量删除对象时,存在部分对象无法删除
* - BadRequestError
- 服务端返回HTTP 400响应
* - ForbiddenError
- 服务端返回HTTP 403响应
* - NotFoundError
- 服务端返回HTTP 404响应
* - MethodNotAllowedError
- 服务端返回HTTP 405响应
* - ConflictError
- 服务端返回HTTP 409响应
* - LengthRequiredError
- 服务端返回HTTP 411响应
* - RequestedRangeNotSatisfiableError
- 服务端返回HTTP 416响应
* - InternalServerErrorError
- 服务端返回HTTP 500响应
* - NotImplementedError
- 服务端返回HTTP 501响应
* - ServiceUnavailableError
- 服务端返回HTTP 503响应

nos.Client的使用和异常处理的示例代码
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

::

try:
resp = client.XXX(
bucket=bucket,
key=key
)
except nos.exceptions.ServiceException as e:
print (
'ServiceException: %s\n'
'status_code: %s\n'
'error_type: %s\n'
'error_code: %s\n'
'request_id: %s\n'
'message: %s\n'
) % (
e,
e.status_code, # 错误http状态码
e.error_type, # NOS服务器定义错误类型
e.error_code, # NOS服务器定义错误码
e.request_id, # 请求ID,有利于nos开发人员跟踪异常请求的错误原因
e.message # 错误描述信息
)
except nos.exceptions.ClientException as e:
print (
'ClientException: %s\n'
'message: %s\n'
) % (
e,
e.message # 客户端错误信息
)

对象操作接口
^^^^^^^^^^^^

Delete Object
:::::::::::::

使用举例

::

resp = client.delete_object(
bucket="string",
key="string"
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240"
}

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。


Delete Multiple Objects
:::::::::::::::::::::::

使用举例

::

resp = client.delete_objects(
bucket="string",
keys=[
"string1",
"string2",
...
],
quiet=True|False
)

参数说明

* bucket(string) -- 桶名。
* objects(list) -- 待删除的对象名称列表。
* quiet(boolean) -- 是否开启安静模式(安静模式不显示具体删除信息)。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"response": xml.etree.ElementTree() # xml.etree.ElementTree类型对象
}

返回值的`response`的字符形式可能如下:

::

<?xml version="1.0" encoding="UTF-8"?>
<DeleteResult>
<Deleted>
<Key>1.jpg</Key>
</Deleted>
<Error>
<Key>2.jpg</Key>
<Code>AccessDenied</Code>
<Message>Access Denied</Message>
</Error>
<Error>
<Key>3.jpg</Key>
<Code>NoSuchKey</Code>
<Message>No Such Key</Message>
</Error>
</DeleteResult>

*注意:下列各项通过xml.etree.ElementTree的成员函数获取具体值时,得到的均为字符串;目前标注的类型为原类型名称,需自行转换。*

.. list-table::
:widths: 10 30
:header-rows: 1

* - Element
- 描述
* - DeleteResult
- | 多重删除的响应容器元素
| 类型:容器
* - Deleted
- | 已被成功删除的容器元素
| 类型:容器
| 父节点:DeleteResult
* - Key
- | 已删除的对象键值
| 类型:字符串
| 父节点:Deleted,Error
* - VersionId
- | 已删除的对象版本号
| 类型:数字
| 父节点:Deleted,Error
* - Error
- | 删除失败的对象版本号
| 类型:容器
| 父节点:DeleteResult
* - Code
- | 删除失败返回的错误码
| 类型:字符串
| 父节点:Error
* - Message
- | 删除失败返回的详细错误描述
| 类型:字符串
| 父节点:Error

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。
* response(xml.etree.ElementTree) -- 包含返回信息的xml对象。


Get Object
::::::::::

使用举例

::

resp = client.get_object(
bucket="string",
key="string",
**kwargs
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。
* kwargs -- 其他可选参数,如下。
* range(string) -- 下载指定的数据块,Range Header参考RFC2616。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"content_length": 1024,
"content_range": "0-1024/234564",
"content_type": "application/octet-stream;charset=UTF-8",
"etag": "3adbbad1791fbae3ec908894c4963870",
"body": StreamingBody()
}

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。
* content_length(integer) -- 返回的数据块的字节数。
* content_range(string) -- 返回的数据块的范围。
* content_type(string) -- 返回的数据块的类型。
* etag(string) -- 对象的哈希值,反应对象内容的更改情况。
* body(StreamingBody) -- 对象数据。


Head Object
:::::::::::

使用举例

::

resp = client.head_object(
bucket="string",
key="string"
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"content_length": 1024,
"content_type": "application/octet-stream;charset=UTF-8",
"etag": "3adbbad1791fbae3ec908894c4963870",
"last_modified": "Mon, 23 May 2016 16:07:15 Asia/Shanghai"
}

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。
* content_length(integer) -- 返回的数据块的字节数。
* content_type(string) -- 返回的数据块的类型。
* etag(string) -- 对象的哈希值,反应对象内容的更改情况。
* last_modified(string) -- 最近一次修改对象的时间。


List Objects
::::::::::::

使用举例

::

resp = client.list_objects(
bucket="string",
**kwargs
)

参数说明

* bucket(string) -- 桶名。
* kwargs -- 其他可选参数。
* delimiter(string) -- 分界符,用于做groupby操作。
* marker(string) -- 字典序的起始标记,只列出该标记之后的部分。
* limit(integer) -- 限定返回的数量,返回的结果小于或等于该值。取值范围:0-1000,默认:100
* prefix(string) -- 只返回Key以特定前缀开头的那些对象。可以使用前缀把一个桶里面的对象分成不同的组,类似文件系统的目录一样。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"response": xml.etree.ElementTree() # xml.etree.ElementTree类型对象
}

返回值的`response`的字符形式可能如下:

::

<?xml version="1.0" encoding="UTF-8"?>
<ListBucketResult xmlns="http://doc.nos.netease.com/2012-03-01">
<Name>dream</Name>
<Prefix>user</Prefix>
<MaxKeys>2</MaxKeys>
<NextMarker>user/yao</NextMarker>
<IsTruncated>true</IsTruncated>
<Contents>
<Key>user/lin</Key>
<LastModified>2012-01-01T12:00:00.000Z</LastModified>
<Etag>258ef3fdfa96f00ad9f27c383fc9acce</ Etag>
<Size>143663</Size>
<StorageClass>Standard</StorageClass>
</Contents>
<Contents>
<Key>user/yao</Key>
<LastModified>2012-01-01T12:00:00.000Z</LastModified>
< Etag>828ef3fdfa96f00ad9f27c383fc9ac7f</ Etag>
<Size>423983</Size>
<StorageClass>Standard</StorageClass>
</Contents>
</ListBucketResult>

*注意:下列各项通过xml.etree.ElementTree的成员函数获取具体值时,得到的均为字符串;目前标注的类型为原类型名称,需自行转换。*

.. list-table::
:widths: 10 35
:header-rows: 1

* - 元素
- 描述
* - Contents
- | 对象元数据,代表一个对象描述
| 类型:容器
| 父节点:ListBucketObjects
| 子节点:Key,LastModified,Size,Etag
* - CommonPrefixes
- | 只有当指定了delimiter分界符时,才会有这个响应
| 类型:字符串
| 父节点:ListBucketObjects
* - delimiter
- | 分界符
| 类型:字符串
| 父节点:ListBucketObjects
* - DisplayName
- | 对象的拥有者
| 类型:字符串
| 父节点:ListBucketObjects.Contents.Owner
* - Etag
- | 对象的哈希描述
| 类型:字符串
| 父节点:ListBucketObjects.Contents
* - ID
- | 对象拥有者的ID
| 类型:字符串
| 父节点:ListBucketObjects.Contents.Owner
* - IsTruncated
- | 是否截断,如果因为设置了limit导致不是所有的数据集都返回,则该值设置为true
| 类型:布尔值
| 父节点:ListBucketObjects
* - Key
- | 对象的名称
| 类型:字符串
| 父节点:ListBucketObjects.Contents
* - LastModified
- | 对象最后修改日期和时间
| 类型:日期 格式:yyyy-MM-dd"T"HH:mm:ss.SSSZ
| 父节点:ListBucketObjects.Contents
* - Marker
- | 列表的起始位置,等于请求参数设置的Marker值
| 类型:字符串
| 父节点:ListBucketObjects
* - NextMark
- | 下一次分页的起点
| 类型:字符串
| 父节点:ListBucketObjects
* - MaxKeys
- | 请求的对象个数限制
| 类型:数字
| 父节点:ListBucketObjects
* - Name
- | 请求的桶名称
| 类型:字符串
| 父节点:ListBucketObjects
* - Owner
- | 桶拥有者
| 类型:容器
| 父节点:ListBucketObjects.contents | CommonPrefixes
| 子节点:DisplayName|ID
* - Prefix
- | 请求的对象的Key的前缀
| 类型:字符串
| 父节点:ListBucketObjects
* - Size
- | 对象的大小字节数
| 类型:数字
| 父节点:ListBucketObjects.contents
* - StorageClasss
- | 存储级别
| 类型:字符串
| 父节点:ListBucketObjects.contents

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。
* response(xml.etree.ElementTree) -- 包含返回信息的xml对象。


Put Object
::::::::::

使用举例

::

resp = client.put_object(
bucket="string",
key="string",
body=serializable_object,
**kwargs
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。
* body(serializable_object) -- 对象内容,可以是文件句柄、字符串、字典等任何可序列化的对象。
* kwargs -- 其他可选参数。
* meta_data(dict) -- 用户自定义的元数据,通过键值对的形式上报,键名和值均为字符串,且键名需以\`x-nos-meta-\`开头。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"etag": "fbacf535f27731c9771645a39863328"
}

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的id号。
* etag(string) -- 对象的哈希值,反应对象内容的更改情况。


Put Object - Copy
:::::::::::::::::

使用举例

::

resp = client.copy_object(
src_bucket="string",
src_key="string",
dest_bucket="string",
dest_key="string"
)

参数说明

* src_bucket(string) -- 来源对象的桶名。
* src_key(string) -- 来源对象的对象名。
* dest_bucket(string) -- 目标对象的桶名。
* dest_key(string) -- 目标对象的对象名。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240"
}

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。


Move Object
:::::::::::

使用举例

::

resp = client.move_object(
src_bucket="string",
src_key="string",
dest_bucket="string",
dest_key="string"
)

参数说明

* src_bucket(string) -- 来源对象的桶名。
* src_key(string) -- 来源对象的对象名。
* dest_bucket(string) -- 目标对象的桶名。
* dest_key(string) -- 目标对象的对象名。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240"
}

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。


Initiate Multipart Upload
:::::::::::::::::::::::::

使用举例

::

resp = client.create_multipart_upload(
bucket="string",
key="string",
**kwargs
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。
* kwargs -- 其他可选参数。
* meta_data(dict) -- 用户自定义的元数据,通过键值对的形式上报,键名和值均为字符串,且键名需以\`x-nos-meta-\`开头。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"response": xml.etree.ElementTree() # xml.etree.ElementTree类型对象
}

返回值的`response`的字符形式可能如下:

::

<?xml version="1.0" encoding="UTF-8"?>
<InitiateMultipartUploadResult>
<Bucket>filestation</Bucket>
<Key>movie.avi</Key>
<UploadId>VXBsb2FkIElEIGZvciA2aWWpbmcncyBteS1tb3S5tMnRzIHVwbG9hZA</UploadId>
</InitiateMultipartUploadResult>

*注意:下列各项通过xml.etree.ElementTree的成员函数获取具体值时,得到的均为字符串;目前标注的类型为原类型名称,需自行转换。*

.. list-table::
:widths: 10 30
:header-rows: 1

* - 元素
- 描述
* - InitiateMultipartUploadResult
- | 响应容器元素
| 类型:容器
| 子节点:Key,Bucket
* - Key
- | 对象的Key
| 类型:字符串
| 父节点:InitiateMultipartUploadResult
* - Bucket
- | 对象的桶
| 类型:字符串
| 父节点:InitiateMultipartUploadResult
* - UploadId
- | 分块上传的ID,用这个ID来作为各块属于这个文件的标识
| 类型:字符串
| 父节点:InitiateMultipartUploadResult

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的id号。
* response(xml.etree.ElementTree) -- 包含返回信息的xml对象。


Upload Part
:::::::::::

使用举例

::

resp = client.upload_part(
bucket="string",
key="string",
part_num=2,
upload_id="string",
body=serializable_object
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。
* part_num(integer) -- 数据分块编码号(1-10000)。
* upload_id(string) -- 数据上传标识号。
* body(serializable_object) -- 对象内容,可以是文件句柄、字符串、字典等任何可序列化的对象。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"etag": "fbacf535f27731c9771645a39863328"
}

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的id号。
* etag(string) -- 对象的哈希值,反应对象内容的更改情况。


Complete Multipart Upload
:::::::::::::::::::::::::

在将所有数据Part都上传完成后,必须调用Complete Multipart Upload API来完成整个文件的Multipart Upload。在执行该操作时,用户必须提供所有有效的数据Part的列表(包括part号码和ETAG);NOS收到用户提交的Part列表后,会逐一验证每个数据Part的有效性。当所有的数据Part验证通过后,NOS将把这些数据part组合成一个完整的Object。
使用x-nos-Object-md5扩展头发送对象的MD5值,用作去重库的建立(Put Object使用Content-MD5建立对象去重库)。

使用举例

::

resp = client.complete_multipart_upload(
bucket="string",
key="string",
upload_id="string",
info=[
{
"part_num": 1,
"etag": "string"
},
{
"part_num": 2,
"etag": "string"
},
...
],
**kwargs
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。
* upload_id(string) -- 数据上传标识号。
* info(list) -- 所有有效的数据Part的列表(包括part号码和etag)
* kwargs -- 其他可选参数,如下。
* object_md5(string) -- 发送对象的md5值,用于后续去重。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"response": xml.etree.ElementTree() # xml.etree.ElementTree类型对象
}

返回值的`response`的字符形式可能如下:

::

<?xml version="1.0" encoding="UTF-8"?>
<CompleteMultipartUploadResult xmlns="">
<Location> filestation.nos.netease.com/movie.avi</Location>
<Bucket>filestation </Bucket>
<Key>movie.avi </Key>
<ETag>"3858f62230ac3c915f300c664312c11f-9"</ETag>
</CompleteMultipartUploadResult>

*注意:下列各项通过xml.etree.ElementTree的成员函数获取具体值时,得到的均为字符串;目前标注的类型为原类型名称,需自行转换。*

.. list-table::
:widths: 10 30
:header-rows: 1

* - 元素
- 描述
* - Bucket
- | 新创建对象所在的桶
| 类型:字符串
| 父节点:CompleteMultipartUploadResult
* - CompleteMultipartUploadResult
- | 响应容器元素
| 类型:容器
| 子节点:Location,Bucket,Key,ETag
* - ETag
- | 新创建的对象的Entity Tag
| 类型:字符串
| 父节点:CompleteMultipartUploadResult
* - Key
- | 新创建对象的Key
| 类型:字符串
| 父节点:CompleteMultipartUploadResult
* - Location
- | 新创建的这个对象的资源定位URL
| 类型:字符串
| 父节点:CompleteMultipartUploadResult

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。
* response(xml.etree.ElementTree) -- 包含返回信息的xml对象。


Abort Multipart Upload
::::::::::::::::::::::

使用举例

::

resp = client.abort_multipart_upload(
bucket="string",
key="string",
upload_id="string"
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。
* upload_id(string) -- 数据上传标识号。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240"
}

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。


List Parts
::::::::::

使用举例

::

resp = client.list_parts(
bucket="string",
key="string",
upload_id="string",
**kwargs
)

参数说明

* bucket(string) -- 桶名。
* key(string) -- 对象名。
* upload_id(string) -- 数据上传标识号。
* kwargs -- 其他可选参数,如下。
* limit(integer) -- 限制响应中返回的记录个数。取值范围:0-1000,默认1000。
* part_number_marker(string) -- 分块号的界限,只有更大的分块号会被列出来。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"response": xml.etree.ElementTree() # xml.etree.ElementTree类型对象
}

返回值的`response`的字符形式可能如下:

::

<?xml version="1.0" encoding="UTF-8"?>
<ListPartsResult xmlns=" ">
<Bucket>example-Bucket</Bucket>
<Key>example-Object</Key>
<UploadId>23r54i252358235332523f23 </UploadId>
<Owner>
<ID>75aa57f09aa0c8caeab4f8c24e99d10f8e7faeebf76c078efc7c6caea54ba06a</ID>
<DisplayName>someName</DisplayName>
</Owner>
<StorageClass>STANDARD</StorageClass>
<PartNumberMarker>1</PartNumberMarker>
<NextPartNumberMarker>3</NextPartNumberMarker>
<MaxParts>2</MaxParts>
<IsTruncated>true</IsTruncated>
<Part>
<PartNumber>2</PartNumber>
<LastModified>2010-11-10T20:48:34.000Z</LastModified>
<ETag>"7778aef83f66abc1fa1e8477f296d394"</ETag>
<Size>10485760</Size>
</Part>
<Part>
<PartNumber>3</PartNumber>
<LastModified>2010-11-10T20:48:33.000Z</LastModified>
<ETag>"aaaa18db4cc2f85cedef654fccc4a4x8"</ETag>
<Size>10485760</Size>
</Part>
</ListPartsResult>

*注意:下列各项通过xml.etree.ElementTree的成员函数获取具体值时,得到的均为字符串;目前标注的类型为原类型名称,需自行转换。*

.. list-table::
:widths: 10 30
:header-rows: 1

* - 元素
- 描述
* - ListPartsResult
- | 列出已上传块信息
| 类型:容器
| 子节点:Bucket、Key、UploadId、Owner、StorageClass、PartNumberMarker、NextPartNumberMarker、MaxParts, IsTruncated、Part
* - Bucket
- | 桶的名称
| 类型: String
| 父节点: ListPartsResult
* - Key
- | 对象的Key
| 类型: String
| 父节点: ListPartsResult
* - UploadId
- | 分块上传操作的ID
| 类型: String
| 父节点: ListPartsResult
* - ID
- | 对象拥有者的ID
| 类型: String
| 父节点: Owner
* - DisplayName
- | 对象的拥有者.
| 类型: String
| 父节点: Owner
* - Owner
- | 桶拥有者的信息
| 子节点:ID, DisplayName
| 类型: 容器
| 父节点: ListPartsResult
* - StorageClass
- | 存储级别.
| 类型: String
| 父节点: ListPartsResult
* - PartNumberMarker
- | 上次List操作后的Part number
| 类型: Integer
| 父节点: ListPartsResult
* - NextPartNumberMarker
- | 作为后续List操作的part-number-marker
| 类型: Integer
| 父节点: ListPartsResult
* - MaxParts
- | 响应允许返回的的最大part数目
| 类型: Integer
| 父节点: ListPartsResult
* - IsTruncated
- | 是否截断,如果因为设置了limit导致不是所有的数据集都返回了,则该值设置为true
| 类型: Boolean
| 父节点: ListPartsResult
* - Part
- | 列出相关part信息
| 子节点:PartNumber, LastModified, ETag, Size
| 类型: String
| 父节点: ListPartsResult
* - PartNumber
- | 识别特定part的一串数字
| 类型: Integer
| 父节点: Part
* - LastModified
- | 该part上传的时间
| 类型: Date
| 父节点: Part
* - ETag
- | 当该part被上传时返回
| 类型: String
| 父节点: Part
* - Size
- | 已上传的 part数据的大小.
| 类型: Integer
| 父节点: Part

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。
* response(xml.etree.ElementTree) -- 包含返回信息的xml对象。


List Multipart Uploads
::::::::::::::::::::::

使用举例:

::

resp = client.list_multipart_uploads(
bucket="string",
**kwargs
)

参数说明

* bucket(string) -- 桶名。
* kwargs -- 其他可选参数,如下。
* limit(integer) -- 限制响应中返回的记录个数。取值范围:0-1000,默认1000。
* key_marker(string) -- 指定某一uploads key,只有大于该key-marker的才会被列出。

返回值举例

::

{
"x_nos_request_id": "17b21e42ac11000001390ab891440240",
"response": xml.etree.ElementTree() # xml.etree.ElementTree类型对象
}

返回值的`response`的字符形式可能如下:

::

<?xml version="1.0" encoding="UTF-8"?>
<ListMultipartUploadsResult xmlns="http://s3.amazonaws.com/doc/2006-03-01/">
<Bucket>Bucket</Bucket>
<NextKeyMarker>my-movie.m2ts</NextKeyMarker>
<Upload>
<Key>my-divisor</Key>
<UploadId>XMgbGlrZSBlbHZpbmcncyBub3QgaGF2aW5nIG11Y2ggbHVjaw</UploadId>
<Owner>
<ID>75aa57f09aa0c8caeab4f8c24e99d10f8e7faeebf76c078efc7c6caea54ba06a</ID>
<DisplayName>OwnerDisplayName</DisplayName>
</Owner>
<StorageClass>STANDARD</StorageClass>
</Upload>
<Upload>
<Key>my-movie.m2ts</Key>
<UploadId>VXBsb2FkIElEIGZvciBlbHZpbcyBteS1tb3ZpZS5tMnRzIHVwbG9hZA</UploadId>
<Owner>
<ID>b1d16700c70b0b05597d7acd6a3f92be</ID>
<DisplayName>OwnerDisplayName</DisplayName>
</Owner>
<StorageClass>STANDARD</StorageClass>
</Upload>
</ListMultipartUploadsResult>

*注意:下列各项通过xml.etree.ElementTree的成员函数获取具体值时,得到的均为字符串;目前标注的类型为原类型名称,需自行转换。*

.. list-table::
:widths: 10 30
:header-rows: 1

* - 元素
- 描述
* - ListMultipartUploadsResult
- | 响应容器元素
| 类型:容器
| 子节点:Bucket,KeyMarker,Upload,NextKeyMarker, owner
* - Bucket
- | 对象的桶
| 类型:字符串
| 父节点:ListMultipartUploadsResult
* - NextKeyMarker
- | 作为后续查询的key-marker
| 类型:String
| 父节点:ListMultipartUploadsResult
* - IsTruncated
- | 是否截断,如果因为设置了limit导致不是所有的数据集都返回了,则该值设置为true
| 类型:Boolean
| 父节点: ListMultipartUploadsResult
* - Upload
- | 类型:容器
| 子节点:Key,UploadId
| 父节点:ListMultipartUploadsResult
* - Key
- | 对象的Key
| 类型:字符串
| 父节点:Upload
* - UploadId
- | 分块上传操作的ID
| 类型String
| 父节点:Upload
* - ID
- | 对象拥有者的ID
| 类型: String
| 父节点: Owner
* - DisplayName
- | 对象的拥有者
| 类型: String
| 父节点: Owner
* - Owner
- | 桶拥有者的信息
| 类型:容器
| 子节点:DisplayName|ID
| 父节点:Upload
* - StorageClass
- | 存储级别
| 类型: String
| 父节点: Upload
* - Initiated
- | 该分块上传操作被初始化的时间
| 类型:Date
| 父节点: Upload
* - ListMultipartUploadsResult.Prefix
- | 当请求中包含了prefix参数时,响应中会填充这一prefix
| 类型:String
| 父节点: ListMultipartUploadsResult

返回值说明
返回值为字典类型

* x_nos_request_id(string) -- 唯一定位一个请求的ID号。
* response(xml.etree.ElementTree) -- 包含返回信息的xml对象。

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nos-python3-sdk-1.0.2.tar.gz (40.2 kB view hashes)

Uploaded Source

Built Distribution

nos_python3_sdk-1.0.2-py3-none-any.whl (21.7 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page