Skip to main content

Typed Argument Parsing with Pydantic

Project description

Pydantic Argparse

Typed Argument Parsing with Pydantic


Help

See documentation for help.

Installation

Installation with pip is simple:

$ pip install pydantic-argparse

Example

import pydantic
import pydantic_argparse


class Arguments(pydantic.BaseModel):
    # Required Args
    string: str = pydantic.Field(description="a required string")
    integer: int = pydantic.Field(description="a required integer")
    flag: bool = pydantic.Field(description="a required flag")

    # Optional Args
    second_flag: bool = pydantic.Field(False, description="an optional flag")
    third_flag: bool = pydantic.Field(True, description="an optional flag")


def main() -> None:
    # Create Parser and Parse Args
    parser = pydantic_argparse.ArgumentParser(
        model=Arguments,
        prog="Example Program",
        description="Example Description",
        version="0.0.1",
        epilog="Example Epilog",
    )
    args = parser.parse_typed_args()

    # Print Args
    print(args)


if __name__ == "__main__":
    main()
$ python3 example.py --help
usage: Example Program [-h] [-v] --string STRING --integer INTEGER --flag |
                       --no-flag [--second-flag] [--no-third-flag]

Example Description

required arguments:
  --string STRING    a required string
  --integer INTEGER  a required integer
  --flag, --no-flag  a required flag

optional arguments:
  --second-flag      an optional flag (default: False)
  --no-third-flag    an optional flag (default: True)

help:
  -h, --help         show this help message and exit
  -v, --version      show program's version number and exit

Example Epilog
$ python3 example.py --string hello --integer 42 --flag
string='hello' integer=42 flag=True second_flag=False third_flag=True

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

pydantic_argparse-0.7.0.tar.gz (15.7 kB view details)

Uploaded Source

Built Distribution

pydantic_argparse-0.7.0-py3-none-any.whl (22.5 kB view details)

Uploaded Python 3

File details

Details for the file pydantic_argparse-0.7.0.tar.gz.

File metadata

  • Download URL: pydantic_argparse-0.7.0.tar.gz
  • Upload date:
  • Size: 15.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.2 Linux/5.15.0-60-generic

File hashes

Hashes for pydantic_argparse-0.7.0.tar.gz
Algorithm Hash digest
SHA256 2715b2bb6867c5af9026d375519f5ff406854d70523747f1e14531ffda37aa59
MD5 091a279ad960e20e16ec283ae955c4e4
BLAKE2b-256 4f19a0b7a76383f185db2aba9be415daacdb15f3af6022bb64604e74c5c560ed

See more details on using hashes here.

File details

Details for the file pydantic_argparse-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: pydantic_argparse-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 22.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.2 Linux/5.15.0-60-generic

File hashes

Hashes for pydantic_argparse-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 229c793a8ec237c5e45f6d20b765a2ce95c322173de50d31c4a6ccfab67f0815
MD5 abe748224a2a9f00fa222d0fc4d95087
BLAKE2b-256 90bc9843de2a7721de04bb0eed44c644ef1f47f6cf6c9a8461661af5afdd5481

See more details on using hashes here.

Supported by

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