Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/raclettes/python-tri
Prettier error handling for Python
https://github.com/raclettes/python-tri
error-handling pip pypi pypi-package python python-3 python3
Last synced: 28 days ago
JSON representation
Prettier error handling for Python
- Host: GitHub
- URL: https://github.com/raclettes/python-tri
- Owner: raclettes
- License: mit
- Created: 2021-05-08T10:57:27.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2021-07-02T17:36:30.000Z (over 3 years ago)
- Last Synced: 2024-11-12T19:11:47.463Z (about 2 months ago)
- Topics: error-handling, pip, pypi, pypi-package, python, python-3, python3
- Language: Python
- Homepage:
- Size: 12.7 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Tri/bi
This package provides wrappers around functions that nicely handle errors. Reducing code clutter and allowing better responses to uses. This package is inspired by [tri-fp](https://www.npmjs.com/package/tri-fp)[![](https://img.shields.io/pypi/v/tribi.svg)](https://pypi.org/project/tribi/)
[![](https://img.shields.io/pypi/implementation/tribi.svg)](https://pypi.org/project/tribi/)## Tri
Tri still lets native exceptions (usually more severe errors) throw, but catches any other errors
```python
>>> from tri import tri, bi
>>> def my_function():
... return 1 / 0 # Zero division error!>>> # This function raises a "native" exception
>>> tri(my_function)()
Traceback (most recent call last):
...
ZeroDivisionError: division by zero>>> def my_other_function():
... raise Exception>>> # This only raises a standard exception, so doesn't fail
>>> tri(my_other_function)()
(Exception(), None)
```### Bi
Bi, on the contrary, handles all errors blindly. This should only be used if you know what you're doing.
```python
>>> bi(my_function)()
(ZeroDivisionError('division by zero'), None)
```## Async
Both `tri` and `bi` support async.### Tri
```python
>>> # Assuming running in async
>>> from tri import atri, abi
>>> async def divide(a, b):
... return a / b>>> # Let's try to divide by zero
>>> await atri(divide(1, 0))
Traceback (most recent call last):
...
ZeroDivisionError: division by zero>>> # And with abi?
>>> await abi(divide(1, 0))
(ZeroDivisionError('division by zero'), None)>>> # If the function takes no params, we can just pass the function name
>>> async def func():
... return "hello">>> await atri(func)
(None, "hello")
```## Real life example
Some examples include...### Safer JSON loading
```python
from tri import bisafer_loads = bi(json.loads)
error, result = safer_loads(data)if error:
# Error handling JSON
print("Invalid JSON")
```