GitPedia

Xknxproject

ETS project parser written in python

From XKNX·Updated June 21, 2026·View on GitHub·

**xknxproject** is a ETS project parser written in python The project is written primarily in Python, distributed under the GNU General Public License v2.0 license, first published in 2022. Key topics include: hacktoberfest, knx.

Latest release: 3.9.03.9.0 Functional blocks and DPAs

(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

python
"""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

Contributors

Showing top 11 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from XKNX/xknxproject via the GitHub API.Last fetched: 6/29/2026