Skip to main content

A library to gather information from ETS project files used for KNX

Project description

(X)KNX Project

Pre-commit Discord codecov

Extracts KNX projects and parses the underlying XML.

This project aims to provide a library that can be used to extract and parse KNX project files and read out useful information including the group addresses, devices, their descriptions and possibly more.

Documentation

Currently, xknxproject supports extracting (password protected) ETS 4, 5 and 6 projects and can obtain the following information:

  • Areas, Lines, Devices and their individual address and channels
  • CommunicationObjectInstance references for their devices (GA assignments)
  • Group Addresses and their DPT type if set
  • The application programs communication objects, their respective flags and the DPT Type
  • Location information of devices (in which rooms they are)
  • Functions assigned to rooms

Caution: Loading a middle-sized project with this tool takes about 1.5 seconds. For bigger projects this might as well be >3s.

Not all supported languages are included in project / application data. If the configured language is not found, the default language will be used - which is manufacturer / product dependent.

Installation

pip install xknxproject

Usage

"""Extract and parse a KNX project file."""
from xknxproject.models import KNXProject
from xknxproject import XKNXProj


knxproj: XKNXProj = XKNXProj(
    path="path/to/your/file.knxproj",
    password="password",  # optional
    language="de-DE",  # optional
)
project: KNXProject = knxproj.parse()

The resulting KNXProject is a typed dictionary and can be used just like a dictionary, or can be exported as JSON. You can find an example file (exported JSON) in our test suite under https://github.com/XKNX/xknxproject/tree/main/test/resources/stubs

The full type definition can be found here: https://github.com/XKNX/xknxproject/blob/main/xknxproject/models/knxproject.py

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

xknxproject-3.7.1.tar.gz (43.4 kB view details)

Uploaded Source

Built Distribution

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

xknxproject-3.7.1-py3-none-any.whl (45.5 kB view details)

Uploaded Python 3

File details

Details for the file xknxproject-3.7.1.tar.gz.

File metadata

  • Download URL: xknxproject-3.7.1.tar.gz
  • Upload date:
  • Size: 43.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for xknxproject-3.7.1.tar.gz
Algorithm Hash digest
SHA256 511a9c2ac8b4f9b02a253235ffc375aab7ffa85426a20477ed107d83aa1a9629
MD5 8c3a04666bc1b1dd8a1d6dbd11f2a040
BLAKE2b-256 14093e8012c4b8297f72fbf536536e321533d7e3fa0c9e21fbb5a60783d333f4

See more details on using hashes here.

File details

Details for the file xknxproject-3.7.1-py3-none-any.whl.

File metadata

  • Download URL: xknxproject-3.7.1-py3-none-any.whl
  • Upload date:
  • Size: 45.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for xknxproject-3.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9fb70d08c1c707f10021f5ac1ef172e118ede0193429b01d76ca385b909f0d4d
MD5 8218655b92bf2783f189e91ff7bb1e0a
BLAKE2b-256 c01b280cf6ebc2d6da722c8f9b011a0f24a8a26c7387ad14d4aa1301a089e046

See more details on using hashes here.

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