Skip to main content

Productivity tool for quickly creating python programs that parse command-line arguments. Stop writing argparse boilerplate code!

Project description

duckargs

tests_badge cov_badge version_badge license_badge

The purpose of this package is to save some typing whenever you want to quickly create a python program that accepts command line arguments. Just run duckargs with the arguments that you want your program to accept, with example values for options, and duckargs will generate the python code for a program that uses argparse to handle those arguments.

Install

Install with pip (python 3x required):

pip install duckargs

Example

Run duckargs from the command line via python -m duckargs, followed by whatever arguments/options/flags you want your program to accept, and duckargs will print the corresponding python code.

$ python -m duckargs positional_arg1 positional_arg2 -i --int-val 4 -f 3.3 -F --file file_that_exists -a -b -c > program.py

After running the above command, the file program.py will contain the following code:

# positional_arg1 positional_arg2 -i --int-val 4 -f 3.3 -F --file file_that_exists -a -b -c

import argparse

def main():
    parser = argparse.ArgumentParser(description='',
                                     formatter_class=argparse.ArgumentDefaultsHelpFormatter)

    parser.add_argument('positional_arg1', help='a string')
    parser.add_argument('positional_arg2', help='a string')
    parser.add_argument('-i', '--int-val', default=4, type=int, help='an int value')
    parser.add_argument('-f', default=3.3, type=float, help='a float value')
    parser.add_argument('-F', '--file', default='file_that_exists', type=argparse.FileType(), help='a filename')
    parser.add_argument('-a', action='store_true', help='a flag')
    parser.add_argument('-b', action='store_true', help='b flag')
    parser.add_argument('-c', action='store_true', help='c flag')
    args = parser.parse_args()

    print(args.positional_arg1)
    print(args.positional_arg2)
    print(args.int_val)
    print(args.f)
    print(args.file)
    print(args.a)
    print(args.b)
    print(args.c)

if __name__ == "__main__":
    main()

Use duckargs in python code

If you want to use duckargs in your own script, you can use the duckargs.generate_python_code function, which accepts a list of command line arguments:

import sys
from duckargs import generate_python_code

python_code = generate_python_code(sys.argv)

Pitfalls

If you have a combination of flags and positional arguments, and you happen to have a flag followed by a positional argument (as in: python -m duckargs -q --quiet positional_arg), duckargs has no way to tell that you wanted a positional arg, so it will assume you want an option -q --quiet with a required argument.

To avoid this, it is recommended to declare your positional arguments first (as in: python -m duckargs positional_arg -q --quiet)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

duckargs-1.0.0-py3-none-any.whl (8.8 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