Skip to main content

Minio Python Library for Amazon S3 Compatible Cloud Storage for Python

Project description

Minio Python Library for Amazon S3 Compatible Cloud Storage |Gitter|
========

The Minio Python Client SDK provides simple APIs to access any Amazon S3
compatible object storage server.

This quickstart guide will show you how to install the client SDK and
execute an example python program. For a complete list of APIs and
examples, please take a look at the `Python Client API
Reference <https://docs.minio.io/docs/python-client-api-reference>`__
documentation.

This document assumes that you have a working
`Python <https://www.python.org/downloads/>`__ setup in place.

Download from pip
-----------------

.. code:: sh

$ pip install minio

Download from source
--------------------

.. code:: sh

$ git clone https://github.com/minio/minio-py
$ cd minio-py
$ python setup.py install

Initialize Minio Client
-----------------------

You need four items in order to connect to Minio object storage server.

.. csv-table::
:header: "Params", "Description"
:widths: 15, 30

"endpoint", "URL to object storage service."
"access_key", "Access key is like user ID that uniquely identifies your account."
"secret_key", "Secret key is the password to your account."
"secure", "Set this value to 'True' to enable secure (HTTPS) access."


.. code:: python

from minio import Minio
from minio.error import ResponseError

minioClient = Minio('play.minio.io:9000',
access_key='Q3AM3UQ867SPQQA43P2F',
secret_key='zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG',
secure=True)

Quick Start Example - File Uploader
-----------------------------------

This example program connects to a Minio object storage server, makes a
bucket on the server and then uploads a file to the bucket.

We will use the Minio server running at https://play.minio.io:9000 in
this example. Feel free to use this service for testing and development.
Access credentials shown in this example are open to the public.

file-uploader.py
~~~~~~~~~~~~~~~~

.. code:: python

# Import Minio library.
from minio import Minio
from minio.error import ResponseError

# Initialize minioClient with an endpoint and access/secret keys.
minioClient = Minio('play.minio.io:9000',
access_key='Q3AM3UQ867SPQQA43P2F',
secret_key='zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG',
secure=True)

# Make a bucket with the make_bucket API call.
try:
minioClient.make_bucket("maylogs", location="us-east-1")
except BucketAlreadyOwnedByYou as err:
pass
except BucketAlreadyExists as err:
pass
except ResponseError as err:
raise
else:
# Put an object 'pumaserver_debug.log' with contents from 'pumaserver_debug.log'.
try:
minioClient.fput_object('maylogs', 'pumaserver_debug.log', '/tmp/pumaserver_debug.log')
except ResponseError as err:
print(err)


Run file-uploader
~~~~~~~~~~~~~~~~~

.. code:: bash

$ python file_uploader.py

$ mc ls play/maylogs/
[2016-05-27 16:41:37 PDT] 12MiB pumaserver_debug.log

API Reference
-------------

The full API Reference is available here. `Complete API
Reference <https://docs.minio.io/docs/python-client-api-reference>`__

API Reference : Bucket Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

- `make\_bucket <https://docs.minio.io/docs/python-client-api-reference#make_bucket>`__
- `list\_buckets <https://docs.minio.io/docs/python-client-api-reference#list_buckets>`__
- `bucket\_exists <https://docs.minio.io/docs/python-client-api-reference#bucket_exists>`__
- `remove\_bucket <https://docs.minio.io/docs/python-client-api-reference#remove_bucket>`__
- `list\_objects <https://docs.minio.io/docs/python-client-api-reference#list_objects>`__
- `list\_incomplete\_uploads <https://docs.minio.io/docs/python-client-api-reference#list_incomplete_uploads>`__
- `get\_bucket\_policy <https://docs.minio.io/docs/python-client-api-reference#get_bucket_policy>`__
- `set\_bucket\_policy <https://docs.minio.io/docs/python-client-api-reference#set_bucket_policy>`__

API Reference : File Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

- `fput\_object <https://docs.minio.io/docs/python-client-api-reference#fput_object>`__
- `fget\_object <https://docs.minio.io/docs/python-client-api-reference#fget_object>`__

API Reference : Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

- `get\_object <https://docs.minio.io/docs/python-client-api-reference#get_object>`__
- `get\_partial\_object <https://docs.minio.io/docs/python-client-api-reference#get_partial_object>`__
- `put\_object <https://docs.minio.io/docs/python-client-api-reference#put_object>`__
- `stat\_object <https://docs.minio.io/docs/python-client-api-reference#stat_object>`__
- `remove\_object <https://docs.minio.io/docs/python-client-api-reference#remove_object>`__
- `remove\_incomplete\_upload <https://docs.minio.io/docs/python-client-api-reference#remove_incomplete_upload>`__

API Reference : Presigned Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

- `presigned\_get\_object <https://docs.minio.io/docs/python-client-api-reference#presigned_get_object>`__
- `presigned\_put_object <https://docs.minio.io/docs/python-client-api-reference#presigned_put_object>`__
- `presigned\_post\_policy <https://docs.minio.io/docs/python-client-api-reference#presigned_post_policy>`__

Full Examples
-------------

Full Examples : Bucket Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

- `list\_buckets.py <https://github.com/minio/minio-py/blob/master/examples/list_buckets.py>`__
- `list\_objects.py <https://github.com/minio/minio-py/blob/master/examples/list_objects.py>`__
- `bucket\_exists.py <https://github.com/minio/minio-py/blob/master/examples/bucket_exists.py>`__
- `make\_bucket.py <https://github.com/minio/minio-py/blob/master/examples/make_bucket.py>`__
- `remove\_bucket.py <https://github.com/minio/minio-py/blob/master/examples/remove_bucket.py>`__
- `list\_incomplete\_uploads.py <https://github.com/minio/minio-py/blob/master/examples/list_incomplete_uploads.py>`__
- `remove\_incomplete\_upload.py <https://github.com/minio/minio-py/blob/master/examples/remove_incomplete_upload.py>`__

Full Examples : File Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

- `fput\_object.py <https://github.com/minio/minio-py/blob/master/examples/fput_object.py>`__
- `fget\_object.py <https://github.com/minio/minio-py/blob/master/examples/fget_object.py>`__

Full Examples : Object Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

- `put\_object.py <https://github.com/minio/minio-py/blob/master/examples/put_object.py>`__
- `get\_object.py <https://github.com/minio/minio-py/blob/master/examples/get_object.py>`__
- `get\_partial\_object.py <https://github.com/minio/minio-py/blob/master/examples/get_partial_object.py>`__
- `remove\_object.py <https://github.com/minio/minio-py/blob/master/examples/remove_object.py>`__
- `stat\_object.py <https://github.com/minio/minio-py/blob/master/examples/stat_object.py>`__

Full Examples : Presigned Operations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

- `presigned\_get\_object.py <https://github.com/minio/minio-py/blob/master/examples/presigned_get_object.py>`__
- `presigned\_put\_object.py <https://github.com/minio/minio-py/blob/master/examplespresigned_put_object.py>`__
- `presigned\_post\_policy.py <https://github.com/minio/minio-py/blob/master/examples/presigned_post_policy.py>`__

Explore Further
---------------

- `Complete Documentation <https://docs.minio.io>`__
- `Minio Python SDK API
Reference <https://docs.minio.io/docs/python-client-api-reference>`__

Contribute
----------

`Contributors Guide <./CONTRIBUTING.md>`__

|PYPI| |Build Status| |Build status|

.. |Gitter| image:: https://badges.gitter.im/Join%20Chat.svg
:target: https://gitter.im/Minio/minio?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge
.. |PYPI| image:: https://img.shields.io/pypi/v/minio.svg
:target: https://pypi.python.org/pypi/minio
.. |Build Status| image:: https://travis-ci.org/minio/minio-py.svg
:target: https://travis-ci.org/minio/minio-py
.. |Build status| image:: https://ci.appveyor.com/api/projects/status/1d05e6nvxcelmrak?svg=true
:target: https://ci.appveyor.com/project/harshavardhana/minio-py


Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

minio-4.0.11.tar.gz (41.1 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

minio-4.0.11-py3.5.egg (107.9 kB view details)

Uploaded Egg

minio-4.0.11-py2.py3-none-any.whl (53.3 kB view details)

Uploaded Python 2Python 3

File details

Details for the file minio-4.0.11.tar.gz.

File metadata

  • Download URL: minio-4.0.11.tar.gz
  • Upload date:
  • Size: 41.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.9.1 tqdm/4.30.0 CPython/3.5.2

File hashes

Hashes for minio-4.0.11.tar.gz
Algorithm Hash digest
SHA256 5b50861d7f129a50b0bcaa9bbc716c2c797eb6b41eb4577c73fd072722009ffd
MD5 c97638a82dbb749f05f19befd761d27e
BLAKE2b-256 ff7e8f91d63f122e78a1d6e9fa848c39d2636aa8ab38b589454ef6b7ab069d5e

See more details on using hashes here.

File details

Details for the file minio-4.0.11-py3.5.egg.

File metadata

  • Download URL: minio-4.0.11-py3.5.egg
  • Upload date:
  • Size: 107.9 kB
  • Tags: Egg
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.9.1 tqdm/4.30.0 CPython/3.5.2

File hashes

Hashes for minio-4.0.11-py3.5.egg
Algorithm Hash digest
SHA256 b7c5ff80bfa945ab8bf41386738ac0bdfe076b6806822c48a92ef9e4e3f0de16
MD5 076b3871b0b899fdd4aed0155db24756
BLAKE2b-256 ced793d91d8fe76ea1853d4f18e47132a42e695d6120588c580b4c7ffe3a43a7

See more details on using hashes here.

File details

Details for the file minio-4.0.11-py2.py3-none-any.whl.

File metadata

  • Download URL: minio-4.0.11-py2.py3-none-any.whl
  • Upload date:
  • Size: 53.3 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/40.7.1 requests-toolbelt/0.9.1 tqdm/4.30.0 CPython/3.5.2

File hashes

Hashes for minio-4.0.11-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 96f6fb2b9ecb40656ae0c8095c4745fa5068f3e51a9a5ca542aea3db8649b456
MD5 eee68dba0c3253e1e65a667a9fde1157
BLAKE2b-256 c00921342c86af6d493c221827b70d4f9af35f02bf79d8f94a08178add566e97

See more details on using hashes here.

Supported by

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