Skip to main content

PyVLX is a wrapper for the Velux KLF 200 API. PyVLX enables you to run scenes and or open and close velux windows.

Project description

PyVLX - controlling VELUX windows with Python

CI

PyVLX uses the Velux KLF 200 interface to control io-Homecontrol devices, e.g. Velux Windows.

Please note: The KLF 200 is discontinued by Velux and even though the KLF 150 is marketed as its replacement device, it does not work with this library (it is missing the local API) unfortunately.

Installation

PyVLX can be installed via:

pip3 install pyvlx

Development

Contributor setup and dependency generation are documented in DEVELOPMENT.md.

Home Assistant Plugin

PyVLX is used within Home Assistant. The HA Velux integration can be added in the HA UI.

Please note that to connect you need to use the WiFi password, not the web login.

For debugging frames enable debug logging for the Velux integration in the HA UI.

Basic Operations

"""Just a demo of the PyVLX module."""
import asyncio
import logging

from pyvlx import Position, PyVLX


async def main() -> None:
    """Demonstrate functionality of PyVLX."""
    pyvlx = PyVLX('pyvlx.yaml')
    # Alternative:
    # pyvlx = PyVLX(host="192.168.2.127", password="velux123")

    # Runing scenes:
    await pyvlx.load_scenes()
    await pyvlx.scenes["All Windows Closed"].run()

    # Changing position of windows:
    await pyvlx.load_nodes()
    await pyvlx.nodes['Bath'].open()
    await pyvlx.nodes['Bath'].close()
    await pyvlx.nodes['Bath'].set_position(Position(position_percent=45))

    # Changing of on-off switches:
    # await pyvlx.nodes['CoffeeMaker'].set_on()
    # await pyvlx.nodes['CoffeeMaker'].set_off()

    # You can easily rename nodes:
    # await pyvlx.nodes["Window 10"].rename("Window 11")

    await pyvlx.disconnect()

if __name__ == '__main__':
    logging.basicConfig(level=logging.DEBUG)
    asyncio.run(main())

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

pyvlx-0.2.32.tar.gz (3.1 MB view details)

Uploaded Source

Built Distribution

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

pyvlx-0.2.32-py3-none-any.whl (93.9 kB view details)

Uploaded Python 3

File details

Details for the file pyvlx-0.2.32.tar.gz.

File metadata

  • Download URL: pyvlx-0.2.32.tar.gz
  • Upload date:
  • Size: 3.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyvlx-0.2.32.tar.gz
Algorithm Hash digest
SHA256 9b807183e26f20bb719f01707fa45a88cdf3c39e9c8e91ea900c76daf898cfb1
MD5 e3ce22f04c8969101a2071794e5a707e
BLAKE2b-256 fda2c8d0c42ecc7b0806f8138ed7b09e5e9d2fb472d5952bdf39a53548e0878a

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyvlx-0.2.32.tar.gz:

Publisher: publish.yml on Julius2342/pyvlx

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

File details

Details for the file pyvlx-0.2.32-py3-none-any.whl.

File metadata

  • Download URL: pyvlx-0.2.32-py3-none-any.whl
  • Upload date:
  • Size: 93.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pyvlx-0.2.32-py3-none-any.whl
Algorithm Hash digest
SHA256 8483749fc89ac173246795e3c6f71538b92bc225d88e85699b7d3ae42ecdd1b6
MD5 e20382abf8998c08411ce71c553f12a2
BLAKE2b-256 702e32e0f8b084ac3d5a594e52539c3244bffdcbb6c67d21060f4042f43c14ef

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyvlx-0.2.32-py3-none-any.whl:

Publisher: publish.yml on Julius2342/pyvlx

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