Skip to main content

A collection of argparse extensions

Project description

Motivation

I was having shower and this name came up.

At the moment this is a collection of argparse extensions I have written and found useful in recent times.

Features

  • @arg_converter decorator to write simple argument value parsers without the argparse.Action boilerplate

  • @subcommand decorator to save you from all the add_subparsers and set_defaults(func=).

  • @cli decorator to generate a command-line interface.

Example

The example below combines all the features, but the tool doesn’t enforce it on you.

If you have an existing argparse.ArgumentParser definition, you should be able to replace it with aarghparse by just changing the initialisation line to parser = aarghparse.ArgumentParser(...).

import datetime as dt

import dateutil.tz

from aarghparse import ArgumentParser, arg_converter, cli


@cli
def calendar_cli(parser: ArgumentParser, subcommand: ArgumentParser.subcommand):
    """
    Command-line calendar.
    """

    parser.add_argument(
        '--date-format',
        default=None,
    )

    @arg_converter
    def tz_arg(value):
        return dateutil.tz.gettz(value)

    @subcommand(
        name="now",
        args=[
            ["--tz", {
                "action": tz_arg,
                "help": "Timezone",
            }],
        ],
    )
    def now_cmd(args):
        """
        Prints today's date.
        """
        date_format = args.date_format or "%Y-%m-%d %H:%M:%S"
        print(dt.datetime.now(tz=args.tz).strftime(date_format))


if __name__ == "__main__":
    calendar_cli.run()

If you install python-dateutil then you can try the above with:

python -m aarghparse.examples.calendar --help
python -m aarghparse.examples.calendar now --help
python -m aarghparse.examples.calendar now --tz "Europe/Riga"
python -m aarghparse.examples.calendar --date-format "%d.%m.%Y." now --tz "Europe/Riga"

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

aarghparse-0.2.0.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

aarghparse-0.2.0-py3-none-any.whl (5.6 kB view details)

Uploaded Python 3

File details

Details for the file aarghparse-0.2.0.tar.gz.

File metadata

  • Download URL: aarghparse-0.2.0.tar.gz
  • Upload date:
  • Size: 4.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6

File hashes

Hashes for aarghparse-0.2.0.tar.gz
Algorithm Hash digest
SHA256 500e14ee131e5c713ea077d1821dbf6b1bc74857425707441f2374a4fefd1dd9
MD5 a9e9d14109a8714a9322ed778004cdf7
BLAKE2b-256 f7104f81202a97aa1b914fb888137148ceb52d787ccc3553fa765c3936efa2b3

See more details on using hashes here.

File details

Details for the file aarghparse-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: aarghparse-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 5.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.6.6

File hashes

Hashes for aarghparse-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 09d8134c7f75639ed20038f991bbbff70982cbef774192a9a035cb28da6641b1
MD5 5eed9bdc667681dfa1cc8c9f72c92548
BLAKE2b-256 a2d6d187093a80372b9224a8c67a9226e030c366d2e668692614f43c7e93d02f

See more details on using hashes here.

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