Skip to main content

Pydantic BaseModel supercharged with helper methods for generic and annotation support

Project description

Super Model for Pydantic

Coverage

A lightweight extension of Pydantic's BaseModel that adds generic type introspection and retrieval of fields annotated with typing.Annotated.

Installation

Install with pip

pip install pydantic-super-model

Features

  • Generic support
  • Able to retrieve field(s) with a specific Annotation

Generic Example

from pydantic_super_model import SuperModel

class UserWithType[T](SuperModel):
    """User model with a generic type."""

    id: T
    name: str

user = UserWithType[int](id=1, name="John Doe")

user_type = user.get_type() # int

Annotation Example

from typing import Annotated
from pydantic_super_model import SuperModel


class _PrimaryKeyAnnotation:
    pass

PrimaryKey = Annotated[int, _PrimaryKeyAnnotation]

class UserWithAnnotation(SuperModel):
    """User model with an Annotation for a field."""

    id: PrimaryKey
    name: str

user = UserWithAnnotation(id=1, name="John Doe")

annotations = user.get_annotated_fields(PrimaryKey)
# {"id": 1}

Documentation

Get Annotated Fields

SuperModel.get_annotated_fields(*annotations) returns a dict of field names to values for fields whose type hints carry any of the provided annotations (either the Annotated[...] alias or the meta annotation type).

It includes falsy values (like 0 or an empty string) and includes None only when the field was explicitly provided. Unset default None values are omitted.

from typing import Annotated
from pydantic_super_model import SuperModel

class _PrimaryKey:
    pass

PrimaryKey = Annotated[int, _PrimaryKey]

class User(SuperModel):
    id: PrimaryKey
    name: str

u = User(id=1, name="Jane")

assert u.get_annotated_fields(PrimaryKey) == {"id": 1}

Explicit None vs. unset default:

class UserOptional(SuperModel):
    id: PrimaryKey | None = None
    name: str

# Unset default None is omitted
assert not UserOptional(name="A").get_annotated_fields(PrimaryKey)

# Explicit None is included
assert UserOptional(id=None, name="B").get_annotated_fields(PrimaryKey) == {"id": None}

FieldNotImplemented Annotation

You can use the FieldNotImplemented annotation to mark fields that should not be set. An example use case are experimental fields that you intend on implementing later.

from typing import Annotated
from pydantic_super_model import SuperModel, FieldNotImplemented

class Experimental(SuperModel):
    test_field: Annotated[int, FieldNotImplemented]
    name: str

# Raises NotImplementedError because the field is provided
Experimental(test_field=1, name="x")

# Optional + unset default is allowed
class ExperimentalOptional(SuperModel):
    test_field: Annotated[int | None, FieldNotImplemented] = None
    name: str

ExperimentalOptional(name="ok")  # ok (field is unset)

Generics

Use get_type() to retrieve the concrete generic type parameter supplied at instantiation time.

from pydantic_super_model import SuperModel

class UserWithType[T](SuperModel):
    id: T
    name: str

u = UserWithType[int](id=1, name="Charlie")

assert u.get_type() is int

Run Tests

  • Install with the dev extra: pip install pydantic-super-model[dev]
  • Run tests with pytest .

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

pydantic_super_model-1.0.3.tar.gz (4.0 kB view details)

Uploaded Source

Built Distribution

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

pydantic_super_model-1.0.3-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

Details for the file pydantic_super_model-1.0.3.tar.gz.

File metadata

  • Download URL: pydantic_super_model-1.0.3.tar.gz
  • Upload date:
  • Size: 4.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for pydantic_super_model-1.0.3.tar.gz
Algorithm Hash digest
SHA256 2bb074a49a4dc24dfc12fa0db5519ca3e121b8d5d000166598a9f9f3b87ee490
MD5 4f86a2fdbc563f6f6560ab3bd615ae11
BLAKE2b-256 b0a1669a5e08a9458138d00afa9aae83898b88cc186a995dcd048c67edc46f2b

See more details on using hashes here.

Provenance

The following attestation bundles were made for pydantic_super_model-1.0.3.tar.gz:

Publisher: publish-to-pypi.yml on julien777z/pydantic-super-model

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pydantic_super_model-1.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for pydantic_super_model-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 9bc14223997739dcc77f78679fcbde2d9b2c494439048292ac96994ff97b339c
MD5 fd232586dea29a1916e6b6342668eec8
BLAKE2b-256 4bc40999df875467502d9c4f74717b495293dc4e242d5c6ffb22f9246ff96ead

See more details on using hashes here.

Provenance

The following attestation bundles were made for pydantic_super_model-1.0.3-py3-none-any.whl:

Publisher: publish-to-pypi.yml on julien777z/pydantic-super-model

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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