Build ArgumentParser from pydantic model.
Project description
pydantic-argify
Build ArgumentParser from pydantic model.
Getting started
High level api
See ./examples/00_getting_started.py
from pydantic import BaseModel, Field
from pydantic_argify import sub_command, main
class ConfigCommand1(BaseModel):
string: str = Field(description="string parameter")
integer: int = Field(description="integer parameter")
class ConfigCommand2(BaseModel):
string: str = Field(description="string parameter")
@sub_command("command1")
def command1(config: ConfigCommand1):
print(config)
@sub_command("command2")
def command2(config: ConfigCommand2):
print(config)
if __name__ == "__main__":
main()
$ poetry run python -m examples.00_getting_started command1 -h
usage: 00_getting_started.py command1 [-h] --string STRING --integer INTEGER
options:
-h, --help show this help message and exit
ConfigCommand1:
--string STRING, -s STRING
string parameter
--integer INTEGER, -i INTEGER
integer parameter
Low level api
from argparse import ArgumentParser
from pydantic import BaseModel, Field
from pydantic_argify import build_parser
class Config(BaseModel):
string: str = Field(description="string parameter")
integer: int = Field(description="integer parameter")
parser = ArgumentParser()
build_parser(parser)
parser.print_help()
usage: basic.py [-h] --string STRING --integer INTEGER
optional arguments:
-h, --help show this help message and exit
Config:
--string STRING, -s STRING
a required string
--integer INTEGER, -i INTEGER
a required integer
What's difference with other projects.
This project is dedicated to crafting an argument parser based on the Pydantic model.
Unlike many other projects where the ArgumentParser functionality is concealed within the library,
this tool aims to simplify its use, even in complex scenarios.
For instance, handling nested sub-parsers like aws s3 cp <some options>
or supporting nested Pydantic models has been a challenge in existing solutions.
This library overcomes these limitations, allowing you to effortlessly incorporate intricate functionalities.
Example
from argparse import ArgumentParser
from pydantic import BaseModel, Field
from pydantic_argify import build_parser
class SubConfigA(BaseModel):
string: str = Field(description="string parameter")
integer: int = Field(description="integer parameter")
class SubConfigB(BaseModel):
double: float = Field(description="a required string")
integer: int = Field(0, description="a required integer")
parser = ArgumentParser()
subparsers = parser.add_subparsers()
build_parser(subparsers.add_parser("alpha"), SubConfigA)
build_parser(subparsers.add_parser("beta"), SubConfigB)
parser.print_help()
usage: sub_parser.py [-h] {alpha,beta} ...
positional arguments:
{alpha,beta}
optional arguments:
-h, --help show this help message and exit
Nested config
See: ./examples/06_nested_field
$ python -m examples.06_nested_field -h
usage: 06_nested_field.py [-h] --name NAME --child.name CHILD.NAME [--child.age CHILD.AGE] --child.is-active CHILD.IS_ACTIVE
options:
-h, --help show this help message and exit
Config:
--name NAME, -n NAME
ChildConfig:
--child.name CHILD.NAME, -c CHILD.NAME
--child.age CHILD.AGE
--child.is-active CHILD.IS_ACTIVE
Additional config
Behaviour of pydantic can be controlled via the Config
class or extra arguments of Field
.
Config
is affected all fields.
Extra arguments of Field
is affected specific field.
cli_disable_prefix
- Prefix of argument of boolean type for `store_false`. Default to
--disable-
cli_enable_prefix
- Prefix of argument of boolean type for `store_true`. Default to
--enable-
Future works
- [ ]: Options completion for bash
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
File details
Details for the file pydantic_argify-0.4.1.tar.gz
.
File metadata
- Download URL: pydantic_argify-0.4.1.tar.gz
- Upload date:
- Size: 10.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.2 CPython/3.11.7 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | eedbc5f7961eb903915e358e00e285a58058f8e62f2e9f2e29b55a7f67f1fb45 |
|
MD5 | fcf3fc0e4f17a5a4c2c8af98aa8fec3a |
|
BLAKE2b-256 | caf34b64060e4d2d10cf2c8b00c66dfd4dd9e51dfcb50082782c72363444a0c1 |
File details
Details for the file pydantic_argify-0.4.1-py3-none-any.whl
.
File metadata
- Download URL: pydantic_argify-0.4.1-py3-none-any.whl
- Upload date:
- Size: 12.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.2 CPython/3.11.7 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 19b7ab42184215d08c80c886f54d8a9cc67c153b1776070f84ff82c18a23d7fa |
|
MD5 | 5f867b61fe000d7c793810d3ad08b60b |
|
BLAKE2b-256 | 8ee3bdad517745af988703def4cb8deff733e8eb39813058a95cc80c5afbd0e3 |