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.31.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.31-py3-none-any.whl (93.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pyvlx-0.2.31.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.31.tar.gz
Algorithm Hash digest
SHA256 f63aff66cb10e6e0f4a0c6e38614bd03771375d27d5cc03fc2c044824030fd27
MD5 5eb14e3e95dfa9475b2a155801b40403
BLAKE2b-256 ac8b00fc78ecefe76fc88d1dd3bb29ec6534d26479d81dec563b73ec0bd57aba

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyvlx-0.2.31.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.31-py3-none-any.whl.

File metadata

  • Download URL: pyvlx-0.2.31-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.31-py3-none-any.whl
Algorithm Hash digest
SHA256 116b1c0d489ec11378bc37e0dfb46ef75f497e876e22dad7293d744ab78acd00
MD5 86e3cda1f9424cba35f7fef9dae0157c
BLAKE2b-256 8efd976c4d590f24a053f160bf9cfe53ec92782a7e6c2629edd392d0cb691565

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyvlx-0.2.31-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