Metadata-Version: 2.0
Name: oss2r
Version: 0.0.1
Summary: Aliyun OSS (Object Storage Service) SDK
Home-page: http://oss.aliyun.com
Author: UNKNOWN
Author-email: UNKNOWN
License: UNKNOWN
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.6
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Requires-Dist: crcmod (>=1.7)
Requires-Dist: requests (!=2.9.0)

Aliyun OSS SDK for Python
==========================

.. image:: https://badge.fury.io/py/oss2.svg
    :target: https://badge.fury.io/py/oss2
.. image:: https://travis-ci.org/aliyun/aliyun-oss-python-sdk.svg?branch=master
    :target: https://travis-ci.org/aliyun/aliyun-oss-python-sdk
.. image:: https://coveralls.io/repos/github/aliyun/aliyun-oss-python-sdk/badge.svg?branch=master
    :target: https://coveralls.io/github/aliyun/aliyun-oss-python-sdk?branch=master

概述
----

阿里云对象存储Python SDK 2.x版本。该版本不和上一个版本（0.x版本）兼容，包的名称为oss2，以避免和先前的版本冲突。


该版本的SDK依赖于第三方HTTP库 `requests <https://github.com/kennethreitz/requests>`_ 以及 `crcmod`。 请按照下述安装方法进行安装。

.. note::

    该版本不包含 `osscmd` 命令行工具

运行环境
--------

Python 2.6，2.7，3.3，3.4，3.5

.. note::

    请不要使用Python 3.3.0、3.3.1，参考 `Python Issue 16658 <https://bugs.python.org/issue16658>`_

安装方法
--------

通过pip安装官方发布的版本（以Linux系统为例）：

.. code-block:: bash

    $ pip install oss2

也可以直接安装解压后的安装包：

.. code-block:: bash

    $ sudo python setup.py install


快速使用
--------

.. code-block:: python

    # -*- coding: utf-8 -*-

    import oss2

    endpoint = 'http://oss-cn-hangzhou.aliyuncs.com' # 假设你的Bucket处于杭州区域

    auth = oss2.Auth('<你的AccessKeyId>', '<你的AccessKeySecret>')
    bucket = oss2.Bucket(auth, endpoint, '<你的Bucket名>')

    # Bucket中的文件名（key）为story.txt
    key = 'story.txt'

    # 上传
    bucket.put_object(key, 'Ali Baba is a happy youth.')

    # 下载
    bucket.get_object(key).read()

    # 删除
    bucket.delete_object(key)

    # 遍历Bucket里所有文件
    for object_info in oss2.ObjectIterator(bucket):
        print(object_info.key)

更多例子请参考examples目录下的代码。

出错处理
--------

除非特别说明，一旦出错，Python SDK的接口就会抛出异常（见oss2.exceptions子模块）。参考下面的例子：

.. code-block:: python

    try:
        result = bucket.get_object(key)
        print(result.read())
    except oss2.exceptions.NoSuchKey as e:
        print('{0} not found: http_status={1}, request_id={2}'.format(key, e.status, e.request_id))

测试
----

首先通过环境变量来设置测试所需的AccessKeyId、AccessKeySecret、Endpoint以及Bucket信息（**请不要使用生产环境的Bucket**）。
以Linux系统为例：

.. code-block:: bash

    $ export OSS_TEST_ACCESS_KEY_ID=<AccessKeyId>
    $ export OSS_TEST_ACCESS_KEY_SECRET=<AccessKeySecret>
    $ export OSS_TEST_ENDPOINT=<endpoint>
    $ export OSS_TEST_BUCKET=<bucket>

    $ export OSS_TEST_STS_ID=<AccessKeyId for testing STS>
    $ export OSS_TEST_STS_KEY=<AccessKeySecret for testing STS>
    $ export OSS_TEST_STS_ARN=<Role ARN for testing STS>


然后通过以下方式运行测试：

.. code-block:: bash

    $ nosetests                          # 请先安装nose

更多使用
--------
- `更多例子 <https://github.com/aliyun/aliyun-oss-python-sdk/tree/master/examples>`_
- `Python SDK API文档 <http://aliyun-oss-python-sdk.readthedocs.org/en/latest>`_
- `官网Python SDK文档 <https://docs.aliyun.com/#/pub/oss/sdk/python-sdk&preface>`_

联系我们
--------
- `阿里云OSS官方网站 <http://oss.aliyun.com>`_
- `阿里云OSS官方论坛 <http://bbs.aliyun.com>`_
- `阿里云OSS官方文档中心 <http://www.aliyun.com/product/oss#Docs>`_
- 阿里云官方技术支持：`提交工单 <https://workorder.console.aliyun.com/#/ticket/createIndex>`_

代码许可
--------
MIT许可证，参见LICENSE文件。


