Skip to main content

JSON encoder that handles datetime, Decimal, UUID, dataclasses, and sets without crashing

Project description

philiprehberger-safe-json

JSON encoder that handles datetime, Decimal, UUID, dataclasses, and sets without crashing.

Install

pip install philiprehberger-safe-json

Usage

from philiprehberger_safe_json import dumps, loads

data = {
    "created": datetime(2026, 3, 13, 12, 0, 0),
    "price": Decimal("19.99"),
    "id": UUID("12345678-1234-5678-1234-567812345678"),
    "tags": {"beta", "release"},
}

json_string = dumps(data)
parsed = loads(json_string)

Datetime and Date

from datetime import datetime, date
from philiprehberger_safe_json import dumps

dumps({"timestamp": datetime(2026, 1, 15, 9, 30, 0)})
# '{"timestamp": "2026-01-15T09:30:00"}'

dumps({"day": date(2026, 1, 15)})
# '{"day": "2026-01-15"}'

Decimal

from decimal import Decimal
from philiprehberger_safe_json import dumps

dumps({"price": Decimal("9.99")})
# '{"price": 9.99}'

dumps({"price": Decimal("9.99")}, decimal_as_string=True)
# '{"price": "9.99"}'

UUID

from uuid import UUID
from philiprehberger_safe_json import dumps

dumps({"id": UUID("abcdef01-2345-6789-abcd-ef0123456789")})
# '{"id": "abcdef01-2345-6789-abcd-ef0123456789"}'

Dataclasses

from dataclasses import dataclass
from philiprehberger_safe_json import dumps

@dataclass
class User:
    name: str
    age: int

dumps({"user": User(name="Alice", age=30)})
# '{"user": {"name": "Alice", "age": 30}}'

Sets and Frozensets

from philiprehberger_safe_json import dumps

dumps({"tags": {"c", "a", "b"}})
# '{"tags": ["a", "b", "c"]}'

Bytes

from philiprehberger_safe_json import dumps

dumps({"data": b"hello"})
# '{"data": "aGVsbG8="}'

Enums

from enum import Enum
from philiprehberger_safe_json import dumps

class Color(Enum):
    RED = "red"
    BLUE = "blue"

dumps({"color": Color.RED})
# '{"color": "red"}'

Path

from pathlib import Path
from philiprehberger_safe_json import dumps

dumps({"file": Path("/home/user/data.txt")})
# '{"file": "/home/user/data.txt"}'

Using SafeJsonEncoder Directly

import json
from philiprehberger_safe_json import SafeJsonEncoder

json.dumps({"key": some_value}, cls=SafeJsonEncoder)

API

Name Description
SafeJsonEncoder json.JSONEncoder subclass that handles datetime, date, Decimal, UUID, dataclass, set, frozenset, bytes, Enum, and Path
SafeJsonEncoder.decimal_as_string Class attribute; when True, Decimal values serialize as strings instead of floats (default: False)
dumps(obj, *, decimal_as_string=False, **kwargs) Serialize to JSON string using SafeJsonEncoder. Accepts all json.dumps keyword arguments
loads(s, **kwargs) Deserialize a JSON string. Pass-through to json.loads for API symmetry

License

MIT

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

philiprehberger_safe_json-0.1.0.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

philiprehberger_safe_json-0.1.0-py3-none-any.whl (4.1 kB view details)

Uploaded Python 3

File details

Details for the file philiprehberger_safe_json-0.1.0.tar.gz.

File metadata

File hashes

Hashes for philiprehberger_safe_json-0.1.0.tar.gz
Algorithm Hash digest
SHA256 4a3b3dc1834ac65ceb84aa8621de306940f3e88c39e75299f46d153f55812be5
MD5 8d833c0adcf65cd91f59ee5f0c8df8d9
BLAKE2b-256 36c1ebc06b62e343c4a9c2b93d1bae28b233200b0d111ea3801dccddce1e6893

See more details on using hashes here.

File details

Details for the file philiprehberger_safe_json-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for philiprehberger_safe_json-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 08af6533de2dc58e82c2a9bbdf16a2f9ffd03a838380212805c8db989a3fd429
MD5 e54ef2e6e8db9a4badfc8d21c3883848
BLAKE2b-256 aeef54953b3333bec6a054b5b42fd7fd62aaf43257bc64051323be6bfc3b2991

See more details on using hashes here.

Supported by

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