Skip to main content

Convert Pydantic from V1 to V2 ♻

Project description

Bump Pydantic ♻️

PyPI - Version PyPI - Python Version PyPI - License

Bump Pydantic is a tool to help you migrate your code from Pydantic V1 to V2.

Note If you find bugs, please report them on the issue tracker.

Table of contents


Installation

The installation is as simple as:

pip install "bump-pydantic @ git+https://github.com/pydantic/bump-pydantic@main"

Usage

bump-pydantic is a CLI tool, hence you can use it from your terminal.

To see the available options, you can run:

bump-pydantic --help

Check diff before applying changes

To check the diff before applying the changes, you can run:

bump-pydantic --diff <package>

Apply changes

To apply the changes, you can run:

bump-pydantic <package>

Rules

You can find below the list of rules that are applied by bump-pydantic.

It's also possible to disable rules by using the --disable option.

BP001: Add default None to Optional[T], Union[T, None] and Any fields

  • ✅ Add default None to Optional[T] fields.

The following code will be transformed:

class User(BaseModel):
    name: Optional[str]

Into:

class User(BaseModel):
    name: Optional[str] = None

BP002: Replace Config class by model_config attribute

  • ✅ Replace Config class by model_config = ConfigDict().
  • ✅ Rename old Config attributes to new model_config attributes.
  • ✅ Add a TODO comment in case the transformation can't be done automatically.
  • ✅ Replace Extra enum by string values.

The following code will be transformed:

from pydantic import BaseModel, Extra


class User(BaseModel):
    name: str

    class Config:
        extra = Extra.forbid

Into:

from pydantic import ConfigDict, BaseModel


class User(BaseModel):
    name: str

    model_config = ConfigDict(extra="forbid")

BP003: Replace Field old parameters to new ones

  • ✅ Replace Field old parameters to new ones.

The following code will be transformed:

from typing import List

from pydantic import BaseModel, Field


class User(BaseModel):
    name: List[str] = Field(..., min_items=1)

Into:

from typing import List

from pydantic import BaseModel, Field


class User(BaseModel):
    name: List[str] = Field(..., min_length=1)

BP004: Replace imports

  • ✅ Replace BaseSettings from pydantic to pydantic_settings.
  • ✅ Replace Color and PaymentCardNumber from pydantic to pydantic_extra_types.

BP003: Replace Config class by model_config

  • ✅ Replace Config class by model_config = ConfigDict().

The following code will be transformed:

class User(BaseModel):
    name: str

    class Config:
        extra = 'forbid'

Into:

class User(BaseModel):
    name: str

    model_config = ConfigDict(extra='forbid')

BP005: Replace GenericModel by BaseModel

  • ✅ Replace GenericModel by BaseModel.

The following code will be transformed:

from typing import Generic, TypeVar
from pydantic.generics import GenericModel

T = TypeVar('T')

class User(GenericModel, Generic[T]):
    name: str

Into:

from typing import Generic, TypeVar

T = TypeVar('T')

class User(BaseModel, Generic[T]):
    name: str

BP006: Replace __root__ by RootModel

  • ✅ Replace __root__ by RootModel.

The following code will be transformed:

from typing import List

from pydantic import BaseModel

class User(BaseModel):
    age: int
    name: str

class Users(BaseModel):
    __root__ = List[User]

Into:

from typing import List

from pydantic import RootModel

class User(BaseModel):
    age: int
    name: str

class Users(RootModel[List[User]]):
    pass

License

This project is licensed under the terms of the MIT license.

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

bump_pydantic-0.0.1.tar.gz (26.4 kB view details)

Uploaded Source

Built Distribution

bump_pydantic-0.0.1-py3-none-any.whl (20.6 kB view details)

Uploaded Python 3

File details

Details for the file bump_pydantic-0.0.1.tar.gz.

File metadata

  • Download URL: bump_pydantic-0.0.1.tar.gz
  • Upload date:
  • Size: 26.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.7.13

File hashes

Hashes for bump_pydantic-0.0.1.tar.gz
Algorithm Hash digest
SHA256 454e3b2f0f5569536a71c80ca9a42f9a9030b1c192acd860b1086c6a43b2d830
MD5 e7766e7ac4855ee8544d6a65c8667610
BLAKE2b-256 29979cefc5fce9310628fd694b4d4fd4a616babb9ab87b07d2975bad51c4aa82

See more details on using hashes here.

File details

Details for the file bump_pydantic-0.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for bump_pydantic-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 31c81b41f449f8b686a72c70369ceb015ec5c58b3b8465c3c8636f01cd3dd7c3
MD5 b8451b3ce48902053f100b7f2aa1ca3e
BLAKE2b-256 f527a662c6bfc4775810a0a66dd3d303437a15433f574680fbd48c805369f403

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