Skip to main content

Async Python client for energieleser devices (stromleser, gasleser, wasserleser, wärmeleser).

Project description

energieleser.py

PyPI Python License: MIT

Async Python client for energieleser smart meter devices.

Talks to the device's local HTTP API and returns typed dataclasses for stromleser.one, gasleser, wasserleser and wärmeleser. Powers the upcoming Home Assistant integration.

Installing / Getting started

pip install energieleser
import asyncio
from energieleser import EnergieleserClient

async def main() -> None:
    async with EnergieleserClient("192.168.1.100") as client:
        device = await client.get_device()
        print(device.device_id, device.device_type)

asyncio.run(main())

More examples in docs/usage.md.

Features

  • Async HTTP client built on aiohttp.
  • Typed, frozen, slotted dataclasses per device family.
  • Automatic device-type detection from device_id prefix.
  • Optional Measurement(value, unit) fields — missing readings stay None instead of raising.
  • Bring-your-own aiohttp.ClientSession, or let the client manage one.
  • Structured exception hierarchy for clean error handling.

Configuration

EnergieleserClient(host, port=80, *, session=None, request_timeout=10.0)

Argument Type Default Description
host str Device IP address or hostname.
port int 80 Device HTTP port.
session aiohttp.ClientSession|None None Reuse an existing session. If None, the client creates and owns its own.
request_timeout float 10.0 Per-request timeout in seconds.

Documentation

Links

Licensing

The code in this project is licensed under the MIT license — see LICENSE.

© nineti GmbH

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

energieleser-0.1.2.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

energieleser-0.1.2-py3-none-any.whl (9.0 kB view details)

Uploaded Python 3

File details

Details for the file energieleser-0.1.2.tar.gz.

File metadata

  • Download URL: energieleser-0.1.2.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for energieleser-0.1.2.tar.gz
Algorithm Hash digest
SHA256 004d5ea0c354da2e1b5fe8be705a9c6676338db43f46fee16d60fcd60fe60e01
MD5 7e8b53b13759852761dfae58cbd7520b
BLAKE2b-256 473b58bbc8c1db2c0000a8cc92f43161633a78b553bec72dcb644da2febc3434

See more details on using hashes here.

Provenance

The following attestation bundles were made for energieleser-0.1.2.tar.gz:

Publisher: release.yml on nineti-GmbH/energieleser.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file energieleser-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: energieleser-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 9.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for energieleser-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 46da6597110c9ab0edd9873b30044d7a13293a99f0ffca502daf85357f41a6c4
MD5 c6916a14efae9d97458ee169bc7aaec3
BLAKE2b-256 1e3db4e8008ef15e520656aaeeac2500580e79596e6d3e15da7ac555f5476ecd

See more details on using hashes here.

Provenance

The following attestation bundles were made for energieleser-0.1.2-py3-none-any.whl:

Publisher: release.yml on nineti-GmbH/energieleser.py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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