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

Uploaded Source

Built Distribution

pyanova_nano-0.2.0-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pyanova_nano-0.2.0.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.0.tar.gz
Algorithm Hash digest
SHA256 8936add668361557b9cdc72e6be186f5f656ebcdb7aa1c7f3f599a50d9ece48c
MD5 f533c821173132047c87384b80177eb1
BLAKE2b-256 03b33fa9f28e12b36fe7e00f529a81356eaa2c6758baacb66f509ea85347aa92

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pyanova_nano-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 21.0 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d451099f7e2a0b21d8a948e82ae82d6d2c635838f2d63a7ddaba9416c3c21b07
MD5 ea47651788a96170476c9ffe33f026ca
BLAKE2b-256 433ba87646bff6a1aff58b1200119afd695854c4cc35e10b575112fcdef0d08d

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