Skip to main content

Arguments parser with class for Python, inspired by StructOpt

Project description

Welcome to ClassOpt 👋

Version License: MIT Twitter: moisutsu

Arguments parser with class for Python, inspired by StructOpt

Install

pip install classopt

Usage

Import ClassOpt and define the Opt class with decorator.

from classopt import ClassOpt

@ClassOpt
class Opt:
    arg_int: int
    arg_str: str

if __name__ == "__main__":
    opt = Opt.from_args()
    print(opt.arg_int, opt.arg_str)

Run with command line arguments.

$ python main.py --arg_int 5 --arg_str hello
5 hello

Advanced Usage

ClassOpt internally uses the standard libraries dataclasses and argparse. And you can specify the argument of argparse.ArgumentParser.add_argument with the metadata of dataclasses.field

from dataclasses import field
from classopt import ClassOpt

@ClassOpt
class Opt:
    positional_arguments: str = field(
        metadata={"name_or_flags": "positional_arguments"}
    )
    short_arg: str = field(metadata={"name_or_flags": "-s"})
    default_int: int = field(metadata={"default": 3})
    store_true: bool = field(metadata={"action": "store_true"})
    nargs: list = field(metadata={"nargs": "+", "type": int})

if __name__ == "__main__":
    opt = Opt.from_args()
    print(opt)
$ python main.py positional_arguments -s short_arg --store_true --nargs 1 2 3
Opt(positional_arguments='positional_arguments', short_arg='short_arg', default_int=3, store_true=True, nargs=[1, 2, 3])

Run tests

poetry run pytest

Author

👤 moisutsu

Show your support

Give a ⭐️ if this project helped you!

📝 License

Copyright © 2021 moisutsu.
This project is MIT licensed.


This README was generated with ❤️ by readme-md-generator

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

classopt-0.1.1.tar.gz (3.4 kB view hashes)

Uploaded Source

Built Distribution

classopt-0.1.1-py3-none-any.whl (3.5 kB view hashes)

Uploaded Python 3

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