Create commandline interface via dataclass-like class
Project description
argclz
Class-based command-line argument parsing for Python that combines the power of argparse with class definitions and
type annotations.
Features
- Type-safe arguments - Automatically infer type conversion from Python type annotations
- Clean syntax - Define arguments as class attributes with straightforward decorators
- Composable - Easily reuse and extend argument definitions through inheritance
- Validation - Built-in validation system with chainable API
- Subcommands - Support for command hierarchies with minimal boilerplate
- Organized help - Group arguments into logical sections for better documentation
Installation
pip install argclz
See Documentation
Quick Start
from argclz import *
class MyArgs(AbstractParser):
verbose: bool = argument('--verbose', help='Enable verbose output')
name: str = argument('-n', '--name', required=True, help='Name of the user')
count: int = argument('--count', default=1, help='Number of times to greet')
def run(self):
for _ in range(self.count):
if self.verbose:
print(f"Greeting with enthusiasm: Hello, {self.name}!")
else:
print(f"Hello, {self.name}!")
if __name__ == '__main__':
MyArgs().main()
Show help:
python my_script.py -h
Expected output:
usage: my_script.py [-h] [--verbose] -n NAME [--count COUNT]
options:
-h, --help show this help message and exit
--verbose Enable verbose output
-n NAME, --name NAME Name of the user
--count COUNT Number of times to greet
Run with:
python my_script.py --name Alice --count 3 --verbose
Core Features
Argument Types
# Regular argument
name: str = argument('-n', '--name', help='Name of the user')
# Boolean flag
verbose: bool = argument('--verbose', help='Enable verbose output')
# Positional argument
filename: str = pos_argument('FILENAME', help='Input file to process')
# Variable-length argument
items: list[str] = var_argument('ITEMS', help='Items to process')
Type Parsers
# Comma-separated values to a tuple of floats
coords: tuple[float, ...] = argument('--coords', type=float_tuple_type)
# Value range (min:max)
ranging: tuple[int, int] = argument('--range', type=int_tuple_type)
Argument Organization
# Grouped arguments
verbose: bool = argument('--verbose', group='general')
output_dir: str = argument('--output', group='output')
# Mutually exclusive arguments
output_json: bool = argument('--json', ex_group='output')
output_yaml: bool = argument('--yaml', ex_group='output')
Validators
# Range validator
age: int = argument('--age', validator.int.in_range(18, 99))
# Path validator
path: Path = argument('--path', validator.path.is_dir().is_exists())
Subcommands
class InitCmd(AbstractParser):
name: str = argument('--name', required=True)
def run(self):
print(f"Initializing project: {self.name}")
class BuildCmd(AbstractParser):
release: bool = argument('--release')
def run(self):
print("Building in release mode" if self.release else "Building in debug mode")
# Entry point
from argclz.commands import parse_command_args
if __name__ == '__main__':
parse_command_args({
'init': InitCmd,
'build': BuildCmd
})
Reusable Option Classes
class IOOptions:
input_path: str = argument('--input', help='Input file')
output_path: str = argument('--output', help='Output file')
class LoggingOptions:
verbose: bool = argument('--verbose', help='Enable verbose logging')
class MyOptions(IOOptions, LoggingOptions):
# Override an inherited argument
input_path = as_argument(IOOptions.input_path).with_options(required=True)
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file argclz-1.0.1.tar.gz.
File metadata
- Download URL: argclz-1.0.1.tar.gz
- Upload date:
- Size: 27.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
69fc0ae1bbdca56aaaa13a1e3892225cbb05fc50c89b03456ce3aee1506d9ddc
|
|
| MD5 |
bf5dbe74da2e2598905ca63bc4c74d6f
|
|
| BLAKE2b-256 |
f8b060d6706ed4168c444bcb1c50c60a44c083f6f600c541417ee1c7916855ea
|
Provenance
The following attestation bundles were made for argclz-1.0.1.tar.gz:
Publisher:
python-publish.yml on ytsimon2004/argclz
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
argclz-1.0.1.tar.gz -
Subject digest:
69fc0ae1bbdca56aaaa13a1e3892225cbb05fc50c89b03456ce3aee1506d9ddc - Sigstore transparency entry: 270367233
- Sigstore integration time:
-
Permalink:
ytsimon2004/argclz@79c728fc752071737bf14e44a41a088b2cc6cf49 -
Branch / Tag:
refs/tags/v1.0.1 - Owner: https://github.com/ytsimon2004
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@79c728fc752071737bf14e44a41a088b2cc6cf49 -
Trigger Event:
push
-
Statement type:
File details
Details for the file argclz-1.0.1-py3-none-any.whl.
File metadata
- Download URL: argclz-1.0.1-py3-none-any.whl
- Upload date:
- Size: 29.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ba3c39fd9999bedd19d51e7ef5c00e780612f72da2d24502cca710d092b2758a
|
|
| MD5 |
dda7377805ceb71c1c103df71cde55e8
|
|
| BLAKE2b-256 |
e471322856d80b7c92f3e9e56ddba164d34ff96f6c62250e696a20773ddd2067
|
Provenance
The following attestation bundles were made for argclz-1.0.1-py3-none-any.whl:
Publisher:
python-publish.yml on ytsimon2004/argclz
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
argclz-1.0.1-py3-none-any.whl -
Subject digest:
ba3c39fd9999bedd19d51e7ef5c00e780612f72da2d24502cca710d092b2758a - Sigstore transparency entry: 270367239
- Sigstore integration time:
-
Permalink:
ytsimon2004/argclz@79c728fc752071737bf14e44a41a088b2cc6cf49 -
Branch / Tag:
refs/tags/v1.0.1 - Owner: https://github.com/ytsimon2004
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@79c728fc752071737bf14e44a41a088b2cc6cf49 -
Trigger Event:
push
-
Statement type: