Skip to main content

A simple package for parsing function arguments from the command line

Project description


A simple, intuitive way to parse command line arguments. Simply make a function, and call parseargs on it.
  • parses data types through annoations (annotations not required for string arguments)
  • parses positional arguments into positional cli arguments with the same name
  • parses optional keyword arguments by adding them as optional cli arguments
  • parses annotated arguments and uses the native cli specification for types
  • adds a description of the command by using the signature of the method.



from parseargs import parseargs

def fun(firstname, lastname:str, number:int = 5):
	print(f"Hello {firstname} {lastname}")
	print(f"Your number is {number}")
	number *= 2
	print(f"Twice your number is {number}")


Now on the command line, you can do:

$ python ricky bobby --number 5

Notice how it will print out 10. If you remove the annotation declaring the number an int, it will instead print out 55, because it will interpret it as a string.

We can get the method signature with:

$ python -h
usage: [-h] [-n NUMBER] firstname lastname

signature = (firstname, lastname: str, number: int = 5)

positional arguments:

optional arguments:
  -h, --help            show this help message and exit
  -n NUMBER, --number NUMBER

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

parseargs-0.0.5.tar.gz (2.4 kB view hashes)

Uploaded source

Built Distribution

parseargs-0.0.5-py3-none-any.whl (2.7 kB view hashes)

Uploaded py3

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Huawei Huawei PSF Sponsor Microsoft Microsoft PSF Sponsor NVIDIA NVIDIA PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page