Skip to main content

Python API to interact with the Anova Nano.

Project description

PyAnova-Nano

Code style: black License

Control the Anova Nano via BLE.

This is a rough translation of dengelke/node-sous-vide.

Notes:

  • The code should be considered experimental at this point.
  • Presumably this library is not compatible with any other Anova model!
  • The PyAnova class is not compatible with c3V6a2Vy/pyanova.

Installation

pip install pyanova-nano

Examples

Automatic discovery

The device should be found automatically based on the service uuid it provides.

Context manager: auto connect and disconnect

import asyncio
from pyanova_nano import PyAnova

async def print_device_sensors():
    async with PyAnova() as client:
        print(await client.get_sensor_values())

asyncio.run(print_device_sensors())

No context manager

import asyncio

from pyanova_nano import PyAnova


async def get_timer():
    client = PyAnova()
    await client.connect()

    print(await client.get_timer())

    await client.disconnect()


asyncio.run(get_timer())

Manual connection

To use a custom address, first discover all relevant devices, then use PyAnova.connect(device=my_anova) with my_anova being the bleak.BLEDevice you want to connect to.

import asyncio

from bleak import BLEDevice

from pyanova_nano import PyAnova


async def print_target_temp():
    client = PyAnova()
    devices: list[BLEDevice] = await client.discover(connect=False, list_all=True)
    # Select the device to use.
    my_anova = next(iter(devices))

    print(f"Found: {my_anova.address}")

    await client.connect(device=my_anova)

    temperature = await client.get_target_temperature()
    print(temperature)
    
    await client.disconnect()


asyncio.run(print_target_temp())

Subscription to status updates

The Anova Nano deos not update the client on it's own. We have to ask it for updates. This library allows you to poll the device for updates and subscribe to be notified.

import asyncio

from pyanova_nano import PyAnova


async def main():
    async with PyAnova() as client:

        def handle_update():
            print(client.last_status)

        client.set_poll_interval(4)
        client.subscribe(handle_update)
        client.start_poll()

        # We should get 3 updates in 10 seconds before stopping the polling.
        await asyncio.sleep(10)
        await client.stop_poll()


asyncio.run(main())

Troubleshooting

Cannot connect to your Anova Nano.

  1. The Anova Nano can only maintain a connection to a single client. Ensure that nothing else is connected to your Anova Nano.
  2. Try turning the device off and on by holding the start/stop button.

Disclaimer

This software may harm your device. Use it at your own risk.

THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM “AS IS” WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyanova_nano-0.2.3.tar.gz (17.6 kB view details)

Uploaded Source

Built Distribution

pyanova_nano-0.2.3-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file pyanova_nano-0.2.3.tar.gz.

File metadata

  • Download URL: pyanova_nano-0.2.3.tar.gz
  • Upload date:
  • Size: 17.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for pyanova_nano-0.2.3.tar.gz
Algorithm Hash digest
SHA256 2c4fb2c19181196f1cd2b19f5a265f695d9a1d0c10ece772ae3b28df9ed07ae2
MD5 23704a7391293d626a8b310408f16fb1
BLAKE2b-256 ebb9fed512b73e70bcbd75eeacac931647c8cec6759177035aac9caf88f9abba

See more details on using hashes here.

File details

Details for the file pyanova_nano-0.2.3-py3-none-any.whl.

File metadata

  • Download URL: pyanova_nano-0.2.3-py3-none-any.whl
  • Upload date:
  • Size: 20.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for pyanova_nano-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 c333ab2a8728fb6acc9a64dfe7eb0447cd6d8e15c88cb7936283a71d536b8420
MD5 7ae9713ecbf2aa2c85482741bed6f05a
BLAKE2b-256 5de94e5f6aff9dc47e0efd29a230928d842adfceba55016f9c5efc70e8da12c4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page