2022-12-14 19:42:24 -08:00
[data:image/s3,"s3://crabby-images/a2078/a2078bf40b82ef87af07949b431f645f99047050" alt="CI "](https://github.com/lordwelch/settngs/actions/workflows/build.yaml)
[data:image/s3,"s3://crabby-images/0cb06/0cb06311e41260f0933d04873390fb3b409f2e54" alt="GitHub release (latest by date) "](https://github.com/lordwelch/settngs/releases/latest)
[data:image/s3,"s3://crabby-images/c99c5/c99c58c8f6f75b2b3c3d003e06aa83283fd4a9c6" alt="PyPI "](https://pypi.org/project/settngs/)
[data:image/s3,"s3://crabby-images/f9907/f9907811735663424a8699064604ebe0c8bad123" alt="PyPI - Downloads "](https://pypistats.org/packages/settngs)
[data:image/s3,"s3://crabby-images/3eb46/3eb46f9978b5e8c64ef16bb2901d22058e31be15" alt="PyPI - License "](https://opensource.org/licenses/MIT)
# Settngs
This library is an attempt to merge reading flags/options from the commandline (argparse) and settings from a file (json).
It is a modified argparse inspired by how [flake8] loads their settings. Note that this does not attempt to be a drop-in replacement for argparse.
Install with pip
```console
pip install settngs
```
2023-01-31 19:18:09 -08:00
A trivial example is included at the bottom of settngs.py with the output below (using bash). For a more complete example see [ComicTagger].
2022-12-14 19:42:24 -08:00
```console
$ python -m settngs
Hello world
$ python -m settngs --hello lordwelch
Hello lordwelch
$ python -m settngs --hello lordwelch -s
Hello lordwelch
2022-12-15 18:53:29 -08:00
Successfully saved settings to settings.json
2022-12-14 19:42:24 -08:00
$ python -m settngs
Hello lordwelch
$ python -m settngs -v
Hello lordwelch
2022-12-15 18:53:29 -08:00
merged_namespace.values.example_verbose=True
2022-12-14 19:42:24 -08:00
$ python -m settngs -v -s
Hello lordwelch
2022-12-15 18:53:29 -08:00
Successfully saved settings to settings.json
merged_namespace.values.example_verbose=True
2022-12-14 19:42:24 -08:00
$ python -m settngs
Hello lordwelch
2022-12-15 18:53:29 -08:00
merged_namespace.values.example_verbose=True
2023-01-31 19:18:09 -08:00
$ cat >settings.json < < EOF
{
"example": {
"hello": "lordwelch",
"verbose": true
},
"persistent": {
"test": false,
"hello": "world"
}
}
EOF
2022-12-14 19:42:24 -08:00
$ python -m settngs --no-verbose
Hello lordwelch
$ python -m settngs --no-verbose -s
Hello lordwelch
2022-12-15 18:53:29 -08:00
Successfully saved settings to settings.json
2022-12-14 19:42:24 -08:00
$ python -m settngs --hello world --no-verbose -s
Hello world
2022-12-15 18:53:29 -08:00
Successfully saved settings to settings.json
2022-12-14 19:42:24 -08:00
$ python -m settngs
Hello world
```
settngs.json at the end:
```json
{
"example": {
"hello": "world",
"verbose": false
2023-01-31 19:18:09 -08:00
},
"persistent": false,
"hello": "world"
2022-12-14 19:42:24 -08:00
}
```
## What happened to the 'i'?
PyPi wouldn't let me use 'settings'
[flake8]: https://github.com/PyCQA/flake8
[ComicTagger]: https://github.com/comictagger/comictagger