Skip to main content

Enhance ArgumentParser with a TCP-based API for argument handling.

Project description

netargparse

A Python library that imbues the standard ArgumentParser with an API for the Python script.

This library is intended as a replacement for the ArgumentParser of the standard argparse library, providing an additional TCP based API for handling the arguments of the script.

A minimal example minimal.py with the ArgumentParser could be

from argparse import ArgumentParser

def add_one(args):
    new_number = args.x + 1
    print(new_number)
    return(new_number)

parser = ArgumentParser()
parser.add_argument("-x", type=int, required=True)
args = parser.parse_args()
add_one(args)

and running the script results in

$ python minimal.py -x 5
6

Replacing the ArgumentParser with the NetArgumentParser from this library:

from netargparse import NetArgumentParser

def add_one(args):
    new_number = args.x + 1
    print(new_number)
    return(new_number)

nap = NetArgumentParser()
nap.parser.add_argument("-x", type=int, required=True)
nap(add_one)

The script can now be run in two modes:

  • main - standalone, same behaviour as above
  • nap - enable the API

Main

All arguments must be passed from the CLI after the main argument.

$ python minimal.py main -x 5
6

Nap

nap makes the script listen on a port and wait for the arguments.

$ python minimal.py nap --port 7000 --http

It is then possible to run the main function of the script by sending an HTTP get request with url parameters as arguments.

For example visit http://localhost:7000/?&-x=5 with a browser and receive the script's return as json.

{"response": 6, "exception": "", "finished": 1}

The following arguments are accepted for the nap mode

$ python minimal.py nap --help
usage: minimal.py nap [-h] [-i IP] -p PORT [--http]

optional arguments:
  -h, --help            show this help message and exit
  -i IP, --ip IP        IP address where NetArgumentParser listens. Default is localhost.
  -p PORT, --port PORT  Port number where NetArgumentParser listens.
  --http                Use http get requests instead of plain tcp messages (requires flask).

Installation

For a minimal installation, where only plain TCP messages are used for communication, run

pip install netargparse

No additional libraries will be installed. All libraries used are part of The Python Standard Library.

If HTTP requests are to be used, run

pip install netargparse[http]

This will also install flask.

Documentation

More documentation can be found in docs.

TODO

  • Windows support

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

netargparse-0.1.1.tar.gz (9.7 kB view details)

Uploaded Source

Built Distribution

netargparse-0.1.1-py3-none-any.whl (10.4 kB view details)

Uploaded Python 3

File details

Details for the file netargparse-0.1.1.tar.gz.

File metadata

  • Download URL: netargparse-0.1.1.tar.gz
  • Upload date:
  • Size: 9.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.9.18 Linux/5.14.0-427.37.1.el9_4.x86_64

File hashes

Hashes for netargparse-0.1.1.tar.gz
Algorithm Hash digest
SHA256 1382942d37a933015acadf1f94cff0569e91b54466f01d456ff0461161910cd1
MD5 1ed5b1333acc9f78e2ada4f83d285ba5
BLAKE2b-256 e8822b32edd626aa6a0f4d02e4fb3f41ff887d6dea8978a2927e76b88ba41f66

See more details on using hashes here.

File details

Details for the file netargparse-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: netargparse-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 10.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.9.18 Linux/5.14.0-427.37.1.el9_4.x86_64

File hashes

Hashes for netargparse-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0a05db794b0992df345a698ece7865439344f84e51025193d19693387fd8cb9a
MD5 6322079350ff4d916a1b373f6476fd3f
BLAKE2b-256 6efc0013f6cac60722850998cc9166d356453fcca0f6ca2759b23f1bb03dad18

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