Martin Rusev 7c5a639cc8 Merge pull request #96 from GetHappie/unicode-decode-fix
Fix UnicecodeDecodeError parsing email
2017-09-28 17:11:13 +02:00
2013-07-23 12:01:59 +03:00
2017-09-18 10:14:48 +02:00
2017-09-18 10:23:27 +02:00
2013-07-22 04:40:29 -07:00
2017-09-17 22:57:05 +02:00

Imbox - Python IMAP for Humans
==============================


.. image:: https://travis-ci.org/martinrusev/imbox.svg?branch=master
   :target: https://travis-ci.org/martinrusev/imbox
   :alt: Build Status


Python library for reading IMAP mailboxes and converting email content to machine readable data

Requirements
------------

Python (3.2, 3.3, 3.4, 3.5, 3.6)


Installation
------------

``pip install imbox``


Usage 
-----

.. code:: python

    from imbox import Imbox

    # SSL Context docs https://docs.python.org/3/library/ssl.html#ssl.create_default_context

    with Imbox('imap.gmail.com',
            username='username',
            password='password',
            ssl=True,
            ssl_context=None) as imbox:

        # Gets all messages
        all_messages = imbox.messages()

        # Unread messages
        unread_messages = imbox.messages(unread=True)

        # Messages sent FROM
        messages_from = imbox.messages(sent_from='martin@amon.cx')

        # Messages sent TO
        messages_from = imbox.messages(sent_to='martin@amon.cx')

        # Messages received before specific date
        messages_from = imbox.messages(date__lt='31-July-2013')

        # Messages received after specific date
        messages_from = imbox.messages(date__gt='30-July-2013')

        # Messages from a specific folder
        messages_folder = imbox.messages(folder='Social')



        for uid, message in all_messages:
        # Every message is an object with the following keys

            message.sent_from
            message.sent_to
            message.subject
            message.headers
            message.message_id
            message.date
            message.body.plain
            message.body.html
            message.attachments

        # To check all available keys
            print(message.keys())


        # To check the whole object, just write

            print(message)

            {
            'headers':
                [{
                    'Name': 'Received-SPF',
                    'Value': 'pass (google.com: domain of ......;'
                },
                {
                    'Name': 'MIME-Version',
                    'Value': '1.0'
                }],
            'body': {
                'plain': ['ASCII'],
                'html': ['HTML BODY']
            },
            'attachments':  [{
                'content': <StringIO.StringIO instance at 0x7f8e8445fa70>,
                'filename': "avatar.png",
                'content-type': 'image/png',
                'size': 80264
            }],
            'date': u 'Fri, 26 Jul 2013 10:56:26 +0300',
            'message_id': u '51F22BAA.1040606',
            'sent_from': [{
                'name': u 'Martin Rusev',
                'email': 'martin@amon.cx'
            }],
            'sent_to': [{
                'name': u 'John Doe',
                'email': 'john@gmail.com'
            }],
            'subject': u 'Hello John, How are you today'
            }


`Changelog <https://github.com/martinrusev/imbox/blob/master/CHANGELOG.md>`_
Description
Python IMAP for Human beings
Readme 326 KiB
Languages
Python 97.5%
omnetpp-msg 2.1%
Makefile 0.4%