Skip to main content

Apply changes as patches to pydanic models.

Project description

pydantic-apply

Installation

Just use pip install pydantic-apply to install the library.

Note: pydantic-apply is compatible with pydantic versions 1.9, 1.10 and even 2.0 (🥳) on Python 3.8, 3.9, 3.10 and 3.11. This is also ensured running all tests on all those versions using tox.

About

With pydantic-apply you can apply changes to your pydantic models by using the ApplyModelMixin it provides:

import pydantic

from pydantic_apply import ApplyModelMixin


class Something(ApplyModelMixin, pydantic.BaseModel):
    name: str
    age: int


obj = Something(name='John Doe', age=42)
obj.apply({
    "age": 43,
})
assert obj.age == 43

As the apply data you may pass any dictionary or other pydanic object as you wish. pydantic objects will be converted to dict's when being applied - but will only use fields that where explicitly set on the model instance. Also note that .apply() will ignore all fields not present in the model, like the model constructor would.

Nested models

pydantic-apply will also know how to apply changes to nested models. If those models are by themself subclasses of ApplyModelMixin it will call apply() on those fields as well. Otherwise the whole attribute will be replaced.

Apply changes when using validate_assignment

When your models have validate_assignment enabled it may become tricky to apply changes to the model. This is due to the fact that you only can assign fields once at a time. But with validate_assignment enabled this means each field assignment will trigger its own validation and this validation might fail as the model state is not completely changes and thus in a "broken" intermediate state.

pydantic-apply will take care of this issue and disable the validation for each assignment while applying the changes. It will also ensure the resulting object will still pass the validation, so you don't have to care about this case at all.

Contributing

If you want to contribute to this project, feel free to just fork the project, create a dev branch in your fork and then create a pull request (PR). If you are unsure about whether your changes really suit the project please create an issue first, to talk about this.

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_apply-0.5.0.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

pydantic_apply-0.5.0-py3-none-any.whl (6.1 kB view details)

Uploaded Python 3

File details

Details for the file pydantic_apply-0.5.0.tar.gz.

File metadata

  • Download URL: pydantic_apply-0.5.0.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for pydantic_apply-0.5.0.tar.gz
Algorithm Hash digest
SHA256 062d592340810e891b3e6580caf3a4345818bb838e6f941babd87de9c4ab45e9
MD5 a0f672153d6dbca53ae76e875c4364c6
BLAKE2b-256 69414383a7d8149a00fc32b1a3dc35b8d28e5c60e13f9326568d435d06873858

See more details on using hashes here.

Provenance

File details

Details for the file pydantic_apply-0.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pydantic_apply-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7b0954f9c4ba46af342bc7d2fb4a0d96217b42db6e540b0390284fd409a18125
MD5 ffeae5a417d3f2f42d0dfb5b652d73a8
BLAKE2b-256 c6355e39e3c4b5e42c82198ebc6ccbc0432451892ff3fe9e6a02a3bc03fecd36

See more details on using hashes here.

Provenance

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