An async implementation of PyAcaia
Project description
pyacaia_async
Async implementation of pyacaia, based on asyncio
and bleak
Usage
import asyncio
from pyacaia_async import AcaiaScale
from pyacaia_async.helpers import find_acaia_devices
async def main()
addresses = await find_acaia_devices()
address = addresses[0]
scale = await AcaiaScale.create(mac=address, is_new_style_scale=False)
await scale.tare()
await scale.startStopTimer()
await scale.resetTimer()
asyncio.run(main())
Callback
Weight and settings are available, if you pass a callback function to the constructor.
In that callback you will either receive objects of type Message
or Settings
. A sample notification handler can look like this and can also be found in decode.py
def notification_handler(sender, data) -> None:
msg = decode(data)[0]
if isinstance(msg, Settings):
print(f"Battery: {msg.battery}")
print(f"Unit: {msg.units}")
elif isinstance(msg, Message):
print(f"Weight: {msg.value}")
scale = await AcaiaScale.create(mac=address, callback=notification_handler)
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
pyacaia_async-0.0.11b4.tar.gz
(20.0 kB
view hashes)
Built Distribution
Close
Hashes for pyacaia_async-0.0.11b4-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 44f7f6ec4e125b24a61337d7b9002e734f2acfda84954f5c8dd79496973e7a93 |
|
MD5 | 533b768022f0bf9f0e65ff8f87a1c683 |
|
BLAKE2b-256 | 934797ef4a59c7e8116fbf150b43e29faa0e4ef73c2e9442c556b8c8b5c86e67 |