Metadata-Version: 1.1
Name: reformer
Version: 0.1.1
Summary: The tool for creating notes
Home-page: https://github.com/Krukov/reformer
Author: Dmitry Krukov
Author-email: glebov.ru@gmail.com
License: MIT
Download-URL: https://github.com/Krukov/reformer/tarball/0.1.1    
Description: ========
        Reformer
        ========
        
        .. image:: https://travis-ci.org/Krukov/reformer.svg?branch=master
            :target: https://travis-ci.org/Krukov/reformer
        
        Simple and beautiful library for data formatting/convert/serialize
        ------------------------------------------------------------------
        
        ::
        
            pip install reformer
        
        
        Why
        ---
        There are many great python libraries for validation, serialization and data formatting search as marshmallow, DRF  etc.
        Usually they base on data validation.
        
        Otherwise reformer design only for data formatting, and in a schema you need to define type of transformation and data source.
        
        How to use
        ----------
        To define schema you need to create Reformer base class::
        
            from reformer import Reformer, Field, MapField, MethodField
        
            class Schema(Reformer):
                _fields_ = ('name', 'surname')
                fullname = Field('name').replace('_', '-')  + ' ' + Field('surname')
                admin = Field('username').at(['admin', 'root'])
                welcome = MapField('username', {
                    'admin': 'Hi bro',
                    'root':  'God?'
                })
                posts_titles = Field('posts').iter(['title'])
                status = ('http://api.com/get_user_status/' + Field('id', to=str)).handle(requests.get)
        
        
            target = {
                'id': 353,
                'name': 'John',
                'surname': 'Black',
                'username': 'admin',
                'posts': [
                    {'title': 'New', 'id': 10},
                    {'title': 'My first post', 'id': 11},
                ]
            }
        
            print(Schema.transform(target))
            # OrderedDict([
            #    ('name', 'John'),
            #    ('surname', 'Black'),
            #    ('fullname', 'John Black'),
            #    ('admin', True),
            #    ('welcome', 'Hi bro'),
            #    ('posts_titles', ['New', 'My first post']),
            #    ('status', 'INIT'),
            # ])
        
        
        *FUTURE*
        ========
         - errors
        
Keywords: reformat format transform serializer schema
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Topic :: Software Development :: Libraries :: Python Modules
