Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hansbug/argsloader
Configuration Parsing and Management Based on ChainLoader
https://github.com/hansbug/argsloader
configuration python3 version-control
Last synced: 3 months ago
JSON representation
Configuration Parsing and Management Based on ChainLoader
- Host: GitHub
- URL: https://github.com/hansbug/argsloader
- Owner: HansBug
- License: apache-2.0
- Created: 2022-02-24T12:49:56.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2022-04-13T13:51:20.000Z (almost 3 years ago)
- Last Synced: 2024-08-11T11:27:45.565Z (6 months ago)
- Topics: configuration, python3, version-control
- Language: Python
- Homepage: https://hansbug.github.io/argsloader/
- Size: 12 MB
- Stars: 0
- Watchers: 1
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# argsloader
[data:image/s3,"s3://crabby-images/a80d1/a80d192b67910b243c1153d9bd16869504a6e06a" alt="PyPI"](https://pypi.org/project/argsloader/)
[data:image/s3,"s3://crabby-images/83e25/83e257067c22cf3b84c042819d26bd7a8801c466" alt="PyPI - Python Version"](https://pypi.org/project/argsloader/)
data:image/s3,"s3://crabby-images/cc7b8/cc7b8590f689de92ae308a415ad281d0f3aa8ccd" alt="Loc"
data:image/s3,"s3://crabby-images/0dc1b/0dc1b763f702140202b9e2f4d690639a7c56abc7" alt="Comments"[data:image/s3,"s3://crabby-images/820d8/820d83a9ad8247158c842c2fc2fddd135fd2f78c" alt="Docs Deploy"](https://github.com/HansBug/argsloader/actions?query=workflow%3A%22Docs+Deploy%22)
[data:image/s3,"s3://crabby-images/89928/89928be86d570a8216fa5376f1d7213ae0a34b31" alt="Code Test"](https://github.com/HansBug/argsloader/actions?query=workflow%3A%22Code+Test%22)
[data:image/s3,"s3://crabby-images/594ac/594ac40d89d4689143b1e2c8b31a1ca4a41c8ef9" alt="Badge Creation"](https://github.com/HansBug/argsloader/actions?query=workflow%3A%22Badge+Creation%22)
[data:image/s3,"s3://crabby-images/42fcc/42fcc4eee2fbbb7c785248da48917c2871fdd69b" alt="Package Release"](https://github.com/HansBug/argsloader/actions?query=workflow%3A%22Package+Release%22)
[data:image/s3,"s3://crabby-images/7ecaf/7ecaf6748dc61bcfac2c636a7a7a032f655902de" alt="codecov"](https://codecov.io/gh/HansBug/argsloader)[data:image/s3,"s3://crabby-images/1f814/1f81477f83db58650e5a5f6ef954df93260e5538" alt="GitHub stars"](https://github.com/HansBug/argsloader/stargazers)
[data:image/s3,"s3://crabby-images/ed971/ed9710c99d86158681060b74890f669ea306a719" alt="GitHub forks"](https://github.com/HansBug/argsloader/network)
data:image/s3,"s3://crabby-images/7d894/7d894d954ae2851e0bdd886951a0b6c790b94355" alt="GitHub commit activity"
[data:image/s3,"s3://crabby-images/f80a8/f80a8f3c624dcc7d0441019fb66dc498d2f42bea" alt="GitHub issues"](https://github.com/HansBug/argsloader/issues)
[data:image/s3,"s3://crabby-images/5d6c7/5d6c7b752251fe6c6937c480dd95ace2b23cf9f6" alt="GitHub pulls"](https://github.com/HansBug/argsloader/pulls)
[data:image/s3,"s3://crabby-images/e5c11/e5c11b923b6ed91e97264251c546dc43eafcd3a4" alt="Contributors"](https://github.com/HansBug/argsloader/graphs/contributors)
[data:image/s3,"s3://crabby-images/3d040/3d040db614a65cd889cf37bd53e7c51d863beb22" alt="GitHub license"](https://github.com/HansBug/argsloader/blob/master/LICENSE)Configuration Parsing and Management Based on [chainloader](https://github.com/HansBug/chainloader).
The argsloader library's main goal is to extract and change configuration data before implementing it using its computational mechanism:
* Reusability of local configuration modules
* Scalability and composition of configuration components
* Constructing complicated configuration data validation quickly
## Installation
You can simply install it with `pip` command line from the official PyPI site.
```shell
pip install argsloader
```For more information about installation, you can refer to [Installation](https://HansBug.github.io/argsloader/main/tutorials/installation/index.html).
## Quick Start
### Painless Try
A simple usage is like above
```python
from argsloader.units import yesno, number, is_type, intervalif __name__ == '__main__':
yn = yesno() # yes-no option
print(yn('yes')) # True
print(yn('no')) # False
print(yn(True)) # True
print(yn(False)) # Falsenum = number() # any number
print(num(1)) # 1
print(num('1.2')) # 1.2
print(num('0x4f')) # 79int_ = number() >> is_type(int) # any int number
print(num(1)) # 1
print(num('0x4f')) # 79
print(num(1.2)) # TypeErrorval_ = number() >> interval.LR(0, 10) # number within [0, 10]
print(num(1)) # 1
print(num(1.2)) # 1.2
print(num(11)) # ValueError```
After the unit is built, it can be used to transform and validate the given value.
### Full Validation
Sometimes, there may be multiple errors in the given value, but if you directly call corresponding loader (i.e. call the pre-defined `__call__` method), only the first error will be raised.
```python
from argsloader.units import is_type, intervalif __name__ == '__main__':
in_ = is_type(int) & interval.LR(0, 10) # int within [0, 10]
print(in_(1)) # OK
print(in_(10)) # OK
print(in_(11.2)) # not an int, not in [0, 10] neither
```The output should be
```
1
10
Traceback (most recent call last):
File "test_main.py", line 7, in
print(in_(11.2)) # not an int, not in [0, 10] neither
File "/home/hansbug/projects/argsloader/argsloader/units/base.py", line 237, in __call__
return self.call(v, 'FIRST')
File "/home/hansbug/projects/argsloader/argsloader/units/base.py", line 249, in call
return self._process(PValue(v, ())).act(err_mode)
File "/home/hansbug/projects/argsloader/argsloader/base/result.py", line 264, in act
raise self._first_error()
File "/home/hansbug/projects/argsloader/argsloader/units/build.py", line 80, in _easy_process
pres = self._transform(v, pvalues)
File "/home/hansbug/projects/argsloader/argsloader/units/build.py", line 105, in _transform
v.value, nested_map(lambda x: x.value, pres)
File "/home/hansbug/projects/argsloader/argsloader/units/type.py", line 43, in _calculate
raise TypeError(f'Value type not match - {_tname(type_)} expected but {_tname(type(v))} found.')
TypeParseError: Value type not match - int expected but float found.
```To resolve this problem, you can use method `call` to show them all.
```python
from argsloader.units import is_type, intervalif __name__ == '__main__':
in_ = is_type(int) & interval.LR(0, 10) # int within [0, 10]
print(in_.call(1)) # OK
print(in_.call(10)) # OK
print(in_.call(11.2)) # not an int, not in [0, 10] neither```
The output should be
```
1
10
Traceback (most recent call last):
File "test_main.py", line 7, in
print(in_.call(11.2))
File "/home/hansbug/projects/argsloader/argsloader/units/base.py", line 249, in call
return self._process(PValue(v, ())).act(err_mode)
File "/home/hansbug/projects/argsloader/argsloader/base/result.py", line 268, in act
raise self._full_error()
argsloader.base.exception.MultipleParseError: (2 errors)
: TypeParseError: Value type not match - int expected but float found.
: ValueParseError: Value not in interval - [0, 10] expected but 11.2 found.
```For further examples and best practice, see
* [Cheat Sheet of Units (still under developing)](https://hansbug.github.io/argsloader/main/tutorials/cheat_sheet/index.html)
* [Example of C51 Configuration](https://hansbug.github.io/argsloader/main/best_practice/c51/index.html)
* [Example of Subprocess Env Manager](https://hansbug.github.io/argsloader/main/best_practice/subprocess_env_manager/index.html)
* [Example of One vs One Configuration](https://hansbug.github.io/argsloader/main/best_practice/one_vs_one/index.html)## Contributing
We appreciate all contributions to improve `argsloader`, both logic and system designs. Please refer to CONTRIBUTING.md for more guides.
## License
`argsloader` released under the Apache 2.0 license.