Skip to content

Krukov/reformer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Reformer

https://travis-ci.org/Krukov/reformer.svg?branch=master

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

About

Python library for data formating

Resources

Stars

Watchers

Forks

Packages

No packages published