Small and easy to use library for working with CLI arguments
Project description
CliArgTools
Use pip to install the CliArgTools: pip install CliArgTools
Small and easy to use cross-platform Python library for working with command line arguments.
CliArgTools allows you to easily get the command line arguments, check if the flags are provided, check if filepath is valid and/or has expected filetype and generate and/or output error message if cli arguments given by the user is incorrect.
Made as simple to use as it gets and mostly for personal use because i was tired of making the same logic again and again for my own apps. So its more of a study project than a serious library.
This library is not intended to be used in any kind of important production environment
Code example:
import cliargtools
FILEPATH = cliargtools.getArgByFlag('-fp') # will add required flag -fp
FILEPATH_VALID = cliargtools.isPathValid(FILEPATH) # will check if path is valid
DEBUG = cliargtools.isFlagPresent(['-debug', '-dbg']) # will check for optional flag -debug
ALL_ARGS = cliargtools.getAllArgs() # will return all the arguments given
if (DEBUG):
# printing our interesting stuff if -debug or -dbg argument is present
print("debug: " + str(DEBUG))
print("some filepath: " + FILEPATH)
print("this path is valid: " + str(FILEPATH_VALID))
print("cli arguments: " + ' '.join(ALL_ARGS))
else:
print("Sadly, no debug, but the program still works!")
GetArgsByFlag
Can be used to get the value provided after any flag.
arguments:
required:
flag
- string or array/tuple of strings that will be used to identify the argument (example:"-i"
,['-f', '-file']
)
optional:
optional: bool = False
specifies if the argument is optional or requireddefaultValue: any
- value that will be returned if not value was given by usererrorMessage: str
- will be printed if any error is present and not optionalerrorMessageIfNoArg: str
- will be printed if flag was given but the value wasn't providederrorMessageIfNoFlag: str
- will be printed if required flag wasn't givendefaultErrors: bool = True
- specifies if default errors will be printed,True
by default.
returns:
str
- string if given by the user after theflag
defaultValue
- if required argument is not given by the user
By default the flag argument will be required by the program, but can be set to optional with optional
keyword argument. In this case will return None
if the value wasn't present.
If argument is not optional will print the default error message, specifying what is wrong with the arguments given by the user.
Error messages can be overriden by the errorMessage
, errorMessageIfNoArg
, and errorMessageIfNoFlag
keyword arguments.
Default error messages can be disabled by setting defaultErrors
to False
getArgByFlag(flag: str | list | tuple,
optional:bool = False,
defaultValue:str = None,
errorMessage:str = None,
errorMessageIfNoArg:str = None,
errorMessageIfNoFlag:str = None,
defaultErrors:bool = True)
isFlagPresent
Can be used to check if the flag is given by the user.
arguments:
required:
flag
- string or array/tuple of stings that will be used to identify the argument (example:"-d"
,['-d', '-debug']
)
optional:
optional: bool = True
specifies if the flag is optional or requirederrorMessage: str
- will be printed if any error is present and not optionaldefaultErrors: bool = True
- specifies if default errors will be printed,True
by default.
returns:
bool
-True
orFalse
value whereTrue
means that argument was given by the user, andFalse
means that it is missing.
By default the flag is optional, it means that no error missage will be printed if the flag is missing and False
will be returned.
This behaviour can be changed by the optional
keyword argument. if optional=False
will print errorMessage
if the flag wasn't present.
Default error messages can be disabled by setting defaultErrors
to False
Error message can be overriden by the errorMessage
keyword argument.
isFlagPresent(flag: str | list | tuple,
optional:bool = True,
errorMessage:str = None,
defaultErrors:bool = True)
isPathValid
Can be used to check if the path is valid and/or file extension matches required.
arguments:
required:
path: str
- path to validate
optional:
expectedFileExtensions: str | list | tuple
string or array/tuple of strings specifying the expected file extensionserrorMessageWrongType: str
- will be printed if path exists but extension doesn't match any of specifiederrorMessagePathInvalid: str
- will be printed if given path doesn't existdefaultErrors: bool: true
- specifies if default errors will be printed,True
by default.
returns:
bool
-True
orFalse
value whereTrue
means that path exists and file extension matches specified(if given), andFalse
means that path is invalid or file extension doesn't match any of the specified.
Default error messages can be disabled by setting defaultErrors
to False
Error messages can be overriden by the errorMessageWrongType
or errorMessagePathInvalid
keyword arguments.
isPathValid(path:str,
expectedFileExtensions: str | list | tuple = None,
errorMessageWrongType: str=None,
errorMessagePathInvalid: str=None,
defaultErrors: bool=True)
getAllArgs
Can be used to get the list of all the arguments given by the user
returns:
list
- list of all the values given as a cli arguments by the user
getAllArgs()
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
File details
Details for the file CliArgTools-1.4.tar.gz
.
File metadata
- Download URL: CliArgTools-1.4.tar.gz
- Upload date:
- Size: 5.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.9.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5edbf099b7509d7f1d9d5cf690d958d612108b20e3d5705ff6bea3afba093030 |
|
MD5 | 4d2f2365ca140e7f5e31f248d8966c3f |
|
BLAKE2b-256 | fea26ca28a2e39183cda5b0c8b285625139541dd60888f065cd7da23a7455dd2 |