No project description provided
Project description
oppapī
Ergonomic option parser on top of dataclasses, inspired by structopt.
Usage
from typing import Optional
from oppapi import from_args, oppapi
@oppapi
class Opt:
"""
Option parser using oppapi
"""
host: str
""" This will be positional argument of type `str` """
port: Optional[int] = 8000
""" Optional argument will be option argument """
opt = from_args(Opt)
print(opt)
The code above generates such option parser that
- Generates parser description from class's docstring
- Generates argument description from field's docstring
- A field will be a positional argument
- An optional field will be an optional argument
See the parser help message:
$ python simple.py -h
usage: simple.py [-h] [-p PORT] host
Option parser using oppapi
positional arguments:
host This will be positional argument of type `str`
optional arguments:
-h, --help show this help message and exit
-p PORT, --port PORT Optional argument will be option argument
Running the program deserializes the command line arguments into an object of the declared class.
$ python simple.py localhost -p 20000
Opt(host='localhost', port=20000)
Supported types
- Primitives (
int
,float
,str
,bool
) - Containers (
List
,Tuple
) typing.Optional
Enum
andIntEnum
datetime
decimal
ipaddress
pathlib
uuid
short
/long
oppapi
generates flag names automatically, but you can specify arbitrary short/long names.
from typing import Optional
from oppapi import from_args, oppapi, field
@oppapi
class Opt:
host: Optional[str] = field(short="-n", long="--hostname")
enum
enum.Enum
and enum.IntEnum
will be an argument with choices parameter.
class Food(Enum):
A = "Apple"
B = "Beer"
C = "Chocolate"
class Price(IntEnum):
A = 10
B = 20
C = 30
@oppapi
class Opt:
food: Food
price: Optional[Price]
usage will be like this:
positional arguments:
{Apple,Beer,Chocolate}
optional arguments:
-h, --help show this help message and exit
-p {10,20,30}, --price {10,20,30}
oppapi converts the command line arguments back to Enum.
$ python choice.py Apple --price 20
Opt(food=<Food.A: 'Apple'>, price=<Price.B: 20>)
List
/Tuple
List
will be an arbitrary number of arguments (nargs="+"
). Tuple
will be a fixed number of arguments (nargs=NUM
).
@oppapi
class Opt:
values: List[int]
opts: Optional[Tuple[int, str, float, bool]]
$ python nargs.py 1 2 3 --opts 10 foo 10.0 True
Opt(values=[1, 2, 3], opts=(10, 'foo', 10.0, True))
SubCommand
Union
of dataclasses will be subcommands.
@oppapi
class Foo:
a: int
@oppapi
class Bar:
a: str
b: Optional[int]
@oppapi
class Opt:
sub: Union[Foo, Bar]
usage: subcommand.py [-h] {foo,bar} ...
positional arguments:
{foo,bar}
optional arguments:
-h, --help show this help message and exit
Flatten
TODO
LICENSE
This project is licensed under 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
Built Distribution
File details
Details for the file oppapi-0.0.6.tar.gz
.
File metadata
- Download URL: oppapi-0.0.6.tar.gz
- Upload date:
- Size: 6.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.9.13 Darwin/21.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e1fe8fc16e2528910751a4da1a62f6d5c8d9b07469ad5ad7396473ba9932434e |
|
MD5 | 9f8758d037acdc61d9413a7e1a8ec2cf |
|
BLAKE2b-256 | a5e3908c4e2a809f51a2d4c263af16c736a520e19c8a98b0ceb99cd1d1eb72a4 |
File details
Details for the file oppapi-0.0.6-py3-none-any.whl
.
File metadata
- Download URL: oppapi-0.0.6-py3-none-any.whl
- Upload date:
- Size: 6.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.13 CPython/3.9.13 Darwin/21.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2d3dd469c144ea636b1ac714e0e5393b1577d274b57d61dd79ba8f41be08a88a |
|
MD5 | 4c2020b5f6baa32590509de4b286abaf |
|
BLAKE2b-256 | b76be40370a1887d9f7a73ea62f53bbcefa5a7e98437a29de3697847502c8463 |