Typed Argument Parsing with Pydantic
Project description
pydantic-argparse
Typed Argument Parsing with Pydantic
Help
Documentation coming soon.
Installation
Install using:
pip3 install pydantic-argparse
Example
import pydantic
import pydantic_argparse
class Arguments(pydantic.BaseModel):
"""Arguments for CLI"""
# Required Args
aaa: str = pydantic.Field(description="I'm a required string")
bbb: int = pydantic.Field(description="I'm a required integer")
ccc: bool = pydantic.Field(description="I'm a required bool")
# Optional Args
ddd: bool = pydantic.Field(False, description="I'm an optional bool (default False)")
eee: bool = pydantic.Field(True, description="I'm an optional bool (default True)")
def main() -> None:
"""Main example function."""
# Create Parser and Parse Args
parser = pydantic_argparse.ArgumentParser(
model=Arguments,
prog="Example",
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 [-h] [-v] --aaa AAA --bbb BBB --ccc | --no-ccc [--ddd] [--no-eee]
Example Description
required arguments:
--aaa AAA I'm a required string
--bbb BBB I'm a required integer
--ccc, --no-ccc I'm a required bool
optional arguments:
--ddd I'm an optional bool (default False)
--no-eee I'm an optional bool (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 --aaa hello --bbb 123 --no-ccc
aaa='hello' bbb=123 ccc=False ddd=False eee=True
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
pydantic-argparse-0.4.0.tar.gz
(13.2 kB
view hashes)
Built Distribution
Close
Hashes for pydantic_argparse-0.4.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6d6644d598ee62f674aa538b62441d5b5a25aab07e1228a0d64b6514649167a6 |
|
MD5 | 80b46e2516e465694366254a2ba723bf |
|
BLAKE2b-256 | 18dc6ec331d3d3c327576ba93944b26562fefee4104fea7c78d3da73e8afe401 |