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_unit():
    client = PyAnova()
    await client.connect()

    print(await client.get_timer())

    await client.disconnect()


asyncio.run(get_unit())

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.1.tar.gz (17.2 kB view details)

Uploaded Source

Built Distribution

pyanova_nano-0.2.1-py3-none-any.whl (20.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pyanova_nano-0.2.1.tar.gz
  • Upload date:
  • Size: 17.2 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.1.tar.gz
Algorithm Hash digest
SHA256 3077c996420fb05cacd0c800880f64d3af7a80a56e5ad92d84c2e738e5c3f3f6
MD5 78147a2f51c8e934abe1374638160634
BLAKE2b-256 5824663b8af4a8b37e495e3a0dc3a22ece3a89227cdb21bce0d976ffd8a953c1

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pyanova_nano-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 20.2 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 13cf4309aa9cf24af6ddc1e8821a004db20ae85910ff4c10aebd7d519ed22345
MD5 f791b004dc0fcbc11398f6854790b2ac
BLAKE2b-256 8145ef38427bf28da7f65db86dd42be9beca000164d89b3c58069b73513e5230

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