This package helps transform an input JSON (as Python dict
) into another
JSON (also dict
) using provided schema.
The main goal behind this package was to enable proxying requests between two systems. The first returns JSON data, which can be transformed and sent to the second system.
Transforming is understood as changing the structure of JSON data. For example, splitting some fields or concatenating fields into other fields. In other words, it is a process of reformatting JSON data preserving values but changing the structure.
Take a look at examples/example-1.py
Output:
{
'full name': 'John Doe',
'age': '30',
'address': 'Main Street,123,New York,USA',
'hobbies': 'MY HOBBIES ARE: football,basketball,tennis'
}
Install the package using PIP:
pip install json_dict_transformer
# or
pip install git+https://github.com/thevops/json-dict-transformer.git@master
The package needs data in Python dict
format. You can convert JSON into dict
using the following code:
import json
with open('data.json') as json_file:
data = json.load(json_file)
print(type(data)) # it should return type `dict`
The schema for mapping uses selectors to point to specific fields. For now, there are only 2 available selectors.
json::<field path>
The selector extracts data from a field. A path is built using dot notation. Please, take a look at the above example.
txt::<string>
The selector adds a string. It can be used to add a splitter or any other text to the output data.
<function>
(Callable object)
Allows to use a function over the data on the left side of that function. A function can be passed from outside. Requires to handle a single argument of type string.
- The first version
- Add support for functions for processing data during transformation
- Fix functions feature