Skip to main content

allow custom class json behavior on builtin json object

Project description

What is this?

A pip module that let you define a __json__ method, that works like the toJSON from JavaScript.
(e.g. it magically gets called whenever someone does json.dumps(your_object))

From a technical perspective, this module is a safe, backwards-compatible, reversable patch to the built-in python json object that allows classes to specify how they should be serialized.

Why?

Because sometimes external code uses something like

import json
json.dumps(list_containing_your_object)

And it simply throws an error no matter how you customize your object

How do I use this for my class?

pip install json-fix

import json_fix # import this before the JSON.dumps gets called

# same file, or different file
class YOUR_CLASS:
    def __json__(self):
        # YOUR CUSTOM CODE HERE
        #    you probably just want to do:
        #        return self.__dict__
        return "a built-in object that is natually json-able"

How do I change how someone elses class is jsonified?

There's 2 ways; the aggressive override_table or the more collaboration-friendly fallback_table. Some really powerful stuff can be done safely with the fallback table.

Override Table

If a pip module defines a class, you can control how it is json-dumped, even if they defined a .__json__() method, by using json.override_table.

  • Note! The "when" (in when-a-rule-is-added) can be very important. Whatever rule was most-recently added will have the highest priority. So, even if a pip module uses the override table, you can override their override by doing import that_module and THEN adding your rule to the override table.
  • Note 2! The override table is capable of changing how built-in types are dumped, be careful!
import json_fix # import this before the JSON.dumps gets called
import json
import pandas as pd

SomeClassYouDidntDefine = pd.DataFrame

# create a boolean function for identifying the class
class_checker = lambda obj: isinstance(obj, SomeClassYouDidntDefine)
# then assign it to a function that does the converting
json.override_table[class_checker] = lambda obj_of_that_class: json.loads(obj_of_that_class.to_json())

json.dumps([ 1, 2, SomeClassYouDidntDefine() ], indent=2) # dumps as expected

Fallback Table

Let's say we want all python classes to be jsonable by default, well we can easily do that with the fallback table. The logic is if notthing in override table, and no .__json__ method, then check the fallback table.

import json_fix # import this before the JSON.dumps gets called
import json

# a checker for custom objects
checker = lambda obj: hasattr(obj, "__dict__")
# use the __dict__ when they don't specify a __json__ method 
json.fallback_table[checker] = lambda obj_with_dict: obj_with_dict.__dict__

class SomeClass:
    def __init__(self):
        self.thing = 10

json.dumps([ 1, 2, SomeClass() ], indent=2) # dumps as expected

Like the override table, the most recently-added checker will have the highest priority.

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

json_fix-1.0.0.tar.gz (3.9 kB view details)

Uploaded Source

Built Distribution

json_fix-1.0.0-py3-none-any.whl (3.8 kB view details)

Uploaded Python 3

File details

Details for the file json_fix-1.0.0.tar.gz.

File metadata

  • Download URL: json_fix-1.0.0.tar.gz
  • Upload date:
  • Size: 3.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.13

File hashes

Hashes for json_fix-1.0.0.tar.gz
Algorithm Hash digest
SHA256 625b3fc2f7c7c8855eb3e6669c366163cc9b95dbf8e8568fa07f42a65b8d4672
MD5 430590f268dfe63bb7b4109863656f29
BLAKE2b-256 3395f9721bad4ebd1980cc930cc14170079d01645031abfbf5545473baee0941

See more details on using hashes here.

File details

Details for the file json_fix-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: json_fix-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 3.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.8.13

File hashes

Hashes for json_fix-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1b7d622572f3c7dd653ce9e5a87a4c645a437be7ee622bc916bccb145789055b
MD5 bbd0fbcbb15e21da04682b52b3b4854e
BLAKE2b-256 f6a27ab49b838badff7f43bae3338b90d8f0ebef3672eb12634b619305a9db62

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page