A custom typecasting utility for Python
Project description
todds_typecasting
Python utilities to cast data according to a specific set of rules.
The main features of this are the CustomCastingDataclass and the auto_cast function decorator.
What separates this from pydantic is ease-of-use and some custom treatment to make use of json.loads().
It's almostly entirely AI generated so use at your own risk.
This will likely be refactored to use pydantic in the future. Or maybe I'll just contribute to pydantic directly. I feel like the auto_cast decorator in particular is a no-brainer, so much easier than building a whole pydantic model for simple functions.
Example Usage
from dataclasses import dataclass
from datetime import datetime
from typing import Optional, Union
from todds_typecasting.todds_typecasting import CustomCastingDataclass, auto_cast
# --- Dataclass example (demonstrates: datetime, list[bool], tuple[int,...], dict with Union value types,
# Union ordering behavior, Optional[float], JSON strings, tuple -> list normalization) ---
@dataclass
class AppConfig(CustomCastingDataclass):
port: int
debug: bool
flags: list[bool]
thresholds: tuple[int, ...]
started_at: datetime
metadata: dict[str, Union[int, float, str]]
mode: Union[str, int] # Order matters: Union[str, int] keeps "7" as a string
threshold: Optional[float] = None # Optional field
cfg = AppConfig(
port="8080", # str -> int
debug="YES", # flexible bool tokens
flags='["true","0","yes"]', # JSON string -> list[bool] => [True, False, True]
thresholds=("1", "2", "3"), # tuple of str -> tuple[int,...]
started_at="2024-05-05T10:00:00", # ISO8601 -> datetime
metadata='{"retries":"3","ratio":"0.75","note":"ok"}', # JSON -> dict[str, Union[int,float,str]]
mode="7", # Union[str, int] => stays "7" (first arm wins)
threshold="0.92", # Optional[float] with str input
)
# Resulting object (Python repr):
# AppConfig(
# port=8080,
# debug=True,
# flags=[True, False, True],
# thresholds=(1, 2, 3),
# started_at=datetime(2024, 5, 5, 10, 0, 0),
# metadata={'retries': 3, 'ratio': 0.75, 'note': 'ok'},
# mode='7',
# threshold=0.92
# )
# --- Decorator example (auto_cast) ---
# Shows: list[int] from tuple of str, Optional[datetime], Optional[list[int]],
# dict with Union value types from JSON string, bool tokens, JSON list for tags.
@auto_cast
def launch_job(
attempts: int,
debug: bool = False,
schedule_at: Optional[datetime] = None,
limits: Optional[list[int]] = None,
tags: list[str] = None,
attributes: Optional[dict[str, Union[int, float, bool]]] = None,
):
return {
"attempts": attempts,
"debug": debug,
"schedule_at": schedule_at,
"limits": limits,
"tags": tags,
"attributes": attributes,
"types": {
"attempts": type(attempts).__name__,
"debug": type(debug).__name__,
"schedule_at": type(schedule_at).__name__ if schedule_at else None,
"limits": type(limits).__name__ if limits else None,
"tags": type(tags).__name__,
"attributes": type(attributes).__name__ if attributes else None,
},
}
result = launch_job(
attempts="5",
debug="true",
schedule_at="2025-01-01T00:00:00",
limits=("1", "2", "3"), # tuple -> list[int]
tags='["alpha","beta"]', # JSON -> list[str]
attributes='{"retries":"3","success":"true","ratio":"0.9"}', # JSON -> dict[str, Union[int,bool,float]]
)
# Returned (illustrative):
# {
# 'attempts': 5,
# 'debug': True,
# 'schedule_at': datetime(2025, 1, 1, 0, 0, 0),
# 'limits': [1, 2, 3],
# 'tags': ['alpha', 'beta'],
# 'attributes': {'retries': 3, 'success': True, 'ratio': 0.9},
# 'types': {
# 'attempts': 'int',
# 'debug': 'bool',
# 'schedule_at': 'datetime',
# 'limits': 'list',
# 'tags': 'list',
# 'attributes': 'dict'
# }
# }
Project details
Release history Release notifications | RSS feed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file todds_typecasting-2025.9.16.tar.gz.
File metadata
- Download URL: todds_typecasting-2025.9.16.tar.gz
- Upload date:
- Size: 16.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4592381d8c62371894872f22d12dbe30543c5778dacd94d82c7f365f9e8c8d56
|
|
| MD5 |
4769c23b3c1b70ddc343446efa164cab
|
|
| BLAKE2b-256 |
43cfeb14fbfbd022ea61df7ed29ae1218182b042bd302ad4b61127ad07e13718
|
Provenance
The following attestation bundles were made for todds_typecasting-2025.9.16.tar.gz:
Publisher:
publish.yml on tch521/todds_typecasting
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
todds_typecasting-2025.9.16.tar.gz -
Subject digest:
4592381d8c62371894872f22d12dbe30543c5778dacd94d82c7f365f9e8c8d56 - Sigstore transparency entry: 523995281
- Sigstore integration time:
-
Permalink:
tch521/todds_typecasting@90fa75f04a629e88b0c485646975312b1493d349 -
Branch / Tag:
refs/tags/v2025.09.16 - Owner: https://github.com/tch521
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@90fa75f04a629e88b0c485646975312b1493d349 -
Trigger Event:
release
-
Statement type:
File details
Details for the file todds_typecasting-2025.9.16-py3-none-any.whl.
File metadata
- Download URL: todds_typecasting-2025.9.16-py3-none-any.whl
- Upload date:
- Size: 12.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a61d1c7c33fac92786afbb8eb6d3454d40a41c35e99cb3aec236e5240aa6db4d
|
|
| MD5 |
c7d322a0cbf3a44b7fe3400f5abba59a
|
|
| BLAKE2b-256 |
4b19c8d581d7d504cb39a67eccbf0956be98850f43122c14abfe965c655b4af0
|
Provenance
The following attestation bundles were made for todds_typecasting-2025.9.16-py3-none-any.whl:
Publisher:
publish.yml on tch521/todds_typecasting
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
todds_typecasting-2025.9.16-py3-none-any.whl -
Subject digest:
a61d1c7c33fac92786afbb8eb6d3454d40a41c35e99cb3aec236e5240aa6db4d - Sigstore transparency entry: 523995292
- Sigstore integration time:
-
Permalink:
tch521/todds_typecasting@90fa75f04a629e88b0c485646975312b1493d349 -
Branch / Tag:
refs/tags/v2025.09.16 - Owner: https://github.com/tch521
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@90fa75f04a629e88b0c485646975312b1493d349 -
Trigger Event:
release
-
Statement type: