An HParams implementation with argparse.
Project description
Argparse HParams
A simple argument parser for hyper-parameters.
Installation
From PyPI:
pip install argparse-hparams
From Github:
pip install git+https://github.com/enhuiz/argparse-hparams.git
Example
from argparse_hparams import dataclass, HParams, Annotated, Flag
@dataclass
class HParamsTest(HParams):
# This will call: parser.add_argument(type=int, default=0)
x: int = 0
# You may annotate custom data for parser.add_argument(...).
# The annotated default will overwrite dataclass default
# This will call: parser.add_argument(type=str.upper, default='bad')
y: Annotated[str, dict(type=str.upper, default="bad")] = "good"
# This will call: parser.add_argument(type=int, nargs=2, default=(2, 3))
pair: Annotated[tuple[int, int], dict(type=int, nargs=2)] = (2, 3)
# This will call: parser.add_argument(action="store_true", default=False)
ok: Flag = False
# when positional is set, the argument is a positional argument
pos: Annotated[str, dict(positional=True)] = ""
if __name__ == "__main__":
test = HParamsTest()
test.show()
$ python example.py
usage: example.py [-h] [--x int] [--y upper] [--pair int int] [--ok] [--default Path] str
example.py: error: the following arguments are required: pos
$ python example.py 123
┌────────────┐
│ HParams │
├────────────┤
│x: 0 │
│y: BAD │
│pair: (2, 3)│
│ok: False │
│pos: 123 │
└────────────┘
$ python example.py --default default.yml 123
┌────────────┐
│ HParams │
├────────────┤
│x: 0 │
│y: 1 │
│pair: [4, 5]│
│ok: False │
│pos: 123 │
└────────────┘
$ python example.py --help
usage: example.py [-h] [--x int] [--y upper] [--pair int int] [--ok] [--default Path] str
positional arguments:
str pos
optional arguments:
-h, --help show this help message and exit
--x int x (default: 0)
--y upper y (default: bad)
--pair int int pair (default: (2, 3))
--ok ok (default: False)
--default Path A YAML configuration file that overrides the defaults (default: None)
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
File details
Details for the file argparse-hparams-0.0.1.dev20211128170409.tar.gz
.
File metadata
- Download URL: argparse-hparams-0.0.1.dev20211128170409.tar.gz
- Upload date:
- Size: 5.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1a8ff62184b105bcc2520c1824791100abb63710f294e4a391b84d861705e60e |
|
MD5 | 906afdeae031970d4ae396e987c2b5ff |
|
BLAKE2b-256 | 2d582ebb43164720047382dc3e943713c1b4dd97f081dbd0308b8f39a2339b39 |
File details
Details for the file argparse_hparams-0.0.1.dev20211128170409-py3-none-any.whl
.
File metadata
- Download URL: argparse_hparams-0.0.1.dev20211128170409-py3-none-any.whl
- Upload date:
- Size: 6.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 662bd5555c52f0ff809f4ca7982cf36309b8999adddc8955f0fba094cadfdabe |
|
MD5 | 380c739912368984f620aa3cf748a8ff |
|
BLAKE2b-256 | 96856eaf79b939dfe0adb0538b2276eb71db4f97ff3f53cceddb75d78761010d |