Universal Python serializer
Project description
d_serialize
Universal converter of all things Python to a dict
. So it can be serialized
to JSON
.
Install
pip install d-serialize
Usage:
from d_serialize import d_serialize
from objects import SomeObject
some_object = SomeObject()
json_values = d_serialize(some_object)
Usage in Flask
from d_serialize import d_serialize
from flask import jsonify
from objects import SomeObject
@app.route('/a_route')
def a_route():
some_object = SomeObject()
json_values = d_serialize(some_object)
return jsonify(json_values)
d_serialize will enumerate all public properties of your object (or dict
) and convert them
to a JSON allowable type. IE:
list, dictionary, string, float, integer or boolean.
Any property that is not one of these types will be converted to a string
. set
and tuple
will be converted to list
.
Dictionary and list properties will be followed to ensure all child objects and values are also converted.
Methods and private properties (starting with _
) are not enumerated.
Any property or attribute that raises an exception will be excluded or
have a None
value.
Example:
Converting a Class instance.
class TestObject:
number_value = 1
float_value = 1.1
def dont_call_me(self):
"""return self.number_value"""
print(d_serialize(TestObject()))
# dict(number_value=1, float_value=1.1)
Release History
1.0.0 First version of this wondrous package. 1.0.1 Check for None when serializing and return None rather than 'None'. Exceptions on getattr return None for value.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for d_serialize-1.0.1-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 61af0015c3ab1bacfba0bbd5a5c102e3390b0f08bb5d3020015f6ef5667ba596 |
|
MD5 | 6e33142c17600903b817f3afe9bda69c |
|
BLAKE2b-256 | 9c59382dab7eebeb300dd25783a25bb4f22ebf81a4437daf80f7309832082781 |