Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. JavaScript
  5. [Gelöst] Helios KWL - Zugriff auf xml

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.3k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.1k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

[Gelöst] Helios KWL - Zugriff auf xml

Scheduled Pinned Locked Moved JavaScript
70 Posts 13 Posters 11.6k Views 13 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • A acidsubway

    @KLVN

    hier das Bild, er zeigt nur eine 1 an.
    Ich habe eine KWL EC 500W ET L, fals es damit was zu tun hat.

    2020-12-21 23_40_32-objects - ioBroker.jpg

    2020-12-21 23_43_23-192.168.0.58_anzeig.htm.jpg

    KLVNK Offline
    KLVNK Offline
    KLVN
    wrote on last edited by
    #40

    @acidsubway sagte in [Gelöst] Helios KWL - Zugriff auf xml:

    hier das Bild, er zeigt nur eine 1 an.
    Ich habe eine KWL EC 500W ET L, fals es damit was zu tun hat.

    Schade, probiere es nochmal mit "v02142ne". Wenn das nicht klappt, ist hier eine Anleitung, wie man an die einzelnen Register gelangt:

    1. Öffne die Seite von Helios, auf der der Feuchtefühler ist
    2. Öffne im Browser die Entwicklertools (meisten Taste F12)
    3. Gehe dort in den Reiter "Network"
    4. Warte etwas, bis die Werte aktualisiert werden und du die Datei "werte8.xml" sieht
    5. Klicke auf die Datei und suche im Reiter "Response" nach dem aktuellen Wert des Feuchtefühlers. Wenn sich der Wert schnell ändert, musst du ggfs. auf der linken Seite wieder die neuste "werte8.xml" anklicken und dort erneut suchen. Deine hohe Luftfeuchte sollte aber schnell herausstechen und sich von den anderen Werten deutlich unterscheiden.
    6. Kopiere die ID, die über dem Wert steht in dein Script (<ID>vxxxxx</ID>)

    Hier noch als Bild. Beispielhaft habe ich die Prozedur für den Außenluft-Fühler gekennzeichnet:
    3cb4196f-64e2-48c1-9f38-ad3a5b3686c1-image.png

    A 1 Reply Last reply
    1
    • V Viper3500

      @KLVN
      Ich habe eine KWL EC 270W ET

      Https benutze ich nicht. Gebe normalerweise nur die IP von der Lüftung im Browser ein.
      Die Werte werden auch einmalig beim Script start ausgelesen, leider nur nicht aktualisiert.

      KLVNK Offline
      KLVNK Offline
      KLVN
      wrote on last edited by
      #41

      @Viper3500 sagte in [Gelöst] Helios KWL - Zugriff auf xml:

      @KLVN
      Ich habe eine KWL EC 270W ET

      Https benutze ich nicht. Gebe normalerweise nur die IP von der Lüftung im Browser ein.
      Die Werte werden auch einmalig beim Script start ausgelesen, leider nur nicht aktualisiert.

      Da bin ich auch ratlos. Mache mal bitte genau die Schritte wie in meinem Beitrag vorher. Also Entwicklertools öffnen und dann abwarten, welche Dateien geladen werden. Gibt es regelmäßig neue Dateien und haben diese auch die richtigen Werte? Für die wichtigsten Werte sind erstmal nur werte4.xml und werte8.xml wichtig.

      Der Fehler bei dir heißt eigentlich, dass der Server (Helios) die Verbindung getrennt hat, was an falschen Login-Daten liegen kann. Aber weil bei dir ja schon Werte geladen werden, kann man einen falschen Login ausschließen.

      Im Forum gibt es mehrere Beiträge zu genau diesem Fehler, aber noch keine perfekte Lösung...


      Füge im Code nach Zeile 84 mal console.log(xml); ein, speichere und starte das Script neu und sende die Ausgabe im Log hier ins Forum, also

      function refreshValues(xml) {
        console.log(xml); // <- einfügen
      
        const regex = /<ID>(?<ID>v\d{5})<\/ID>\s*?<VA>(?<VALUE>.*?)<\/VA>/gm;
        var elements = xml.matchAll(regex);
      ...
      

      Irgendwas scheint da schief zu laufen, sodass nichts ankommt.

      V 1 Reply Last reply
      1
      • KLVNK KLVN

        @acidsubway sagte in [Gelöst] Helios KWL - Zugriff auf xml:

        hier das Bild, er zeigt nur eine 1 an.
        Ich habe eine KWL EC 500W ET L, fals es damit was zu tun hat.

        Schade, probiere es nochmal mit "v02142ne". Wenn das nicht klappt, ist hier eine Anleitung, wie man an die einzelnen Register gelangt:

        1. Öffne die Seite von Helios, auf der der Feuchtefühler ist
        2. Öffne im Browser die Entwicklertools (meisten Taste F12)
        3. Gehe dort in den Reiter "Network"
        4. Warte etwas, bis die Werte aktualisiert werden und du die Datei "werte8.xml" sieht
        5. Klicke auf die Datei und suche im Reiter "Response" nach dem aktuellen Wert des Feuchtefühlers. Wenn sich der Wert schnell ändert, musst du ggfs. auf der linken Seite wieder die neuste "werte8.xml" anklicken und dort erneut suchen. Deine hohe Luftfeuchte sollte aber schnell herausstechen und sich von den anderen Werten deutlich unterscheiden.
        6. Kopiere die ID, die über dem Wert steht in dein Script (<ID>vxxxxx</ID>)

        Hier noch als Bild. Beispielhaft habe ich die Prozedur für den Außenluft-Fühler gekennzeichnet:
        3cb4196f-64e2-48c1-9f38-ad3a5b3686c1-image.png

        A Offline
        A Offline
        acidsubway
        wrote on last edited by
        #42

        @KLVN
        du bist mein HELD

        es war "v02136": "Feuchtefuehler_intern" jetzt geht es.

        MEGA DANKE!!!!!!!!!!!!!!!!!!!!!!!!

        1 Reply Last reply
        1
        • KLVNK KLVN

          @Viper3500 sagte in [Gelöst] Helios KWL - Zugriff auf xml:

          @KLVN
          Ich habe eine KWL EC 270W ET

          Https benutze ich nicht. Gebe normalerweise nur die IP von der Lüftung im Browser ein.
          Die Werte werden auch einmalig beim Script start ausgelesen, leider nur nicht aktualisiert.

          Da bin ich auch ratlos. Mache mal bitte genau die Schritte wie in meinem Beitrag vorher. Also Entwicklertools öffnen und dann abwarten, welche Dateien geladen werden. Gibt es regelmäßig neue Dateien und haben diese auch die richtigen Werte? Für die wichtigsten Werte sind erstmal nur werte4.xml und werte8.xml wichtig.

          Der Fehler bei dir heißt eigentlich, dass der Server (Helios) die Verbindung getrennt hat, was an falschen Login-Daten liegen kann. Aber weil bei dir ja schon Werte geladen werden, kann man einen falschen Login ausschließen.

          Im Forum gibt es mehrere Beiträge zu genau diesem Fehler, aber noch keine perfekte Lösung...


          Füge im Code nach Zeile 84 mal console.log(xml); ein, speichere und starte das Script neu und sende die Ausgabe im Log hier ins Forum, also

          function refreshValues(xml) {
            console.log(xml); // <- einfügen
          
            const regex = /<ID>(?<ID>v\d{5})<\/ID>\s*?<VA>(?<VALUE>.*?)<\/VA>/gm;
            var elements = xml.matchAll(regex);
          ...
          

          Irgendwas scheint da schief zu laufen, sodass nichts ankommt.

          V Offline
          V Offline
          Viper3500
          wrote on last edited by
          #43

          @KLVN said in [Gelöst] Helios KWL - Zugriff auf xml:

          console.log(xml);

          Die Dateien werden im Entwicklertool aktualisiert.
          In der LOG steht jetzt:

          javascript.0 2020-12-22 20:55:25.301 error (21624) Request error: Error: socket hang up
          javascript.0 2020-12-22 20:55:25.301 error (21624) Error in request callback: TypeError: Cannot read property 'matchAll' of undefined
          javascript.0 2020-12-22 20:55:25.300 info (21624) script.js.helios2: undefined

          Ich hatte ein älteres Script vorher benutzt welches aber nur die Werte ausgelesen hat. Dieses hat alle Werte ständig aktualisiert:

          var position_anfang, result, position_ende;
          var request= require('request');
           
          var Hlogin = {headers: {
                          'Host': '192.168.1.39',
                          'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:68.0) Gecko/20100101 Firefox/68.0',
                          'Accept': '*/*',
                          'Accept-Language': 'de,en-US;q=0.7,en;q=0.3',
                          'Accept-Encoding': 'gzip, deflate',
                          'Referer': 'http://192.168.1.39/',
                          'Content-Type': 'text/plain;charset=UTF-8',
                          'Content-Length': '15',
                          'DNT': '1',
                          'Connection': 'keep-alive',
                          },
                      url: 'http://192.168.1.39/info.htm',
                      body: 'v00402=!helios!', /*Passwort*/
                      method: 'POST',};
           
          var Hwerte8 = {headers: {
                          'Host': '192.168.1.39',
                          'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:68.0) Gecko/20100101 Firefox/68.0',
                          'Accept': '*/*',
                          'Accept-Language': 'de,en-US;q=0.7,en;q=0.3',
                          'Accept-Encoding': 'gzip, deflate',
                          'Referer': 'http://192.168.1.39/anzeig.htm',
                          'Content-Type': 'text/plain;charset=UTF-8',
                          'Content-Length': '20',
                          'DNT': '1',
                          'Connection': 'keep-alive'
                          },
                      url: 'http://192.168.1.39/data/werte8.xml',
                      body: 'xml=/data/werte8.xml',
                      method: 'POST'};
           
          //Datenpunkte erzeugen
          createState("HeliosKWL.Aussentemperatur");
          createState("HeliosKWL.Zulufttemperatur");
          createState("HeliosKWL.Ablufttemperatur");
          createState("HeliosKWL.Fortlufttemperatur");
          createState("HeliosKWL.Lüfterstufe");
          createState("HeliosKWL.Betriebsart");
          //createState("HeliosKWL.Bypass");
           
          //Login alle 5 Min
          setInterval(function() {
              request(Hlogin);
           }, 300000);
           
          //Datenabfrage alle 5 Sek
          setInterval(function() {
              request(Hwerte8, function (error, response, result) {
                  position_anfang = result.indexOf('v00104') + 1;
                  position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                  position_ende = position_anfang;
                  position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 3;
                  setState('HeliosKWL.Aussentemperatur', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
              });
              request(Hwerte8, function (error, response, result) {
                  position_anfang = result.indexOf('v00105') + 1;
                  position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                  position_ende = position_anfang;
                  position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 3;
                  setState('HeliosKWL.Zulufttemperatur', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
              });
              request(Hwerte8, function (error, response, result) {
                  position_anfang = result.indexOf('v00107') + 1;
                  position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                  position_ende = position_anfang;
                  position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 3;
                  setState('HeliosKWL.Ablufttemperatur', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
              });
              request(Hwerte8, function (error, response, result) {
                  position_anfang = result.indexOf('v00106') + 1;
                  position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                  position_ende = position_anfang;
                  position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 3;
                  setState('HeliosKWL.Fortlufttemperatur', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
              });
              request(Hwerte8, function (error, response, result) {
                  position_anfang = result.indexOf('v00102') + 1;
                  position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                  position_ende = position_anfang;
                  position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 0;
                  setState('HeliosKWL.Lüfterstufe', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
              });
                  request(Hwerte8, function (error, response, result) {
                  position_anfang = result.indexOf('v00101') + 1;
                  position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                  position_ende = position_anfang;
                  position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 0;
                  setState('HeliosKWL.Betriebsart', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
              });
          
          }, 5000);
          
          A 1 Reply Last reply
          0
          • V Viper3500

            @KLVN said in [Gelöst] Helios KWL - Zugriff auf xml:

            console.log(xml);

            Die Dateien werden im Entwicklertool aktualisiert.
            In der LOG steht jetzt:

            javascript.0 2020-12-22 20:55:25.301 error (21624) Request error: Error: socket hang up
            javascript.0 2020-12-22 20:55:25.301 error (21624) Error in request callback: TypeError: Cannot read property 'matchAll' of undefined
            javascript.0 2020-12-22 20:55:25.300 info (21624) script.js.helios2: undefined

            Ich hatte ein älteres Script vorher benutzt welches aber nur die Werte ausgelesen hat. Dieses hat alle Werte ständig aktualisiert:

            var position_anfang, result, position_ende;
            var request= require('request');
             
            var Hlogin = {headers: {
                            'Host': '192.168.1.39',
                            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:68.0) Gecko/20100101 Firefox/68.0',
                            'Accept': '*/*',
                            'Accept-Language': 'de,en-US;q=0.7,en;q=0.3',
                            'Accept-Encoding': 'gzip, deflate',
                            'Referer': 'http://192.168.1.39/',
                            'Content-Type': 'text/plain;charset=UTF-8',
                            'Content-Length': '15',
                            'DNT': '1',
                            'Connection': 'keep-alive',
                            },
                        url: 'http://192.168.1.39/info.htm',
                        body: 'v00402=!helios!', /*Passwort*/
                        method: 'POST',};
             
            var Hwerte8 = {headers: {
                            'Host': '192.168.1.39',
                            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:68.0) Gecko/20100101 Firefox/68.0',
                            'Accept': '*/*',
                            'Accept-Language': 'de,en-US;q=0.7,en;q=0.3',
                            'Accept-Encoding': 'gzip, deflate',
                            'Referer': 'http://192.168.1.39/anzeig.htm',
                            'Content-Type': 'text/plain;charset=UTF-8',
                            'Content-Length': '20',
                            'DNT': '1',
                            'Connection': 'keep-alive'
                            },
                        url: 'http://192.168.1.39/data/werte8.xml',
                        body: 'xml=/data/werte8.xml',
                        method: 'POST'};
             
            //Datenpunkte erzeugen
            createState("HeliosKWL.Aussentemperatur");
            createState("HeliosKWL.Zulufttemperatur");
            createState("HeliosKWL.Ablufttemperatur");
            createState("HeliosKWL.Fortlufttemperatur");
            createState("HeliosKWL.Lüfterstufe");
            createState("HeliosKWL.Betriebsart");
            //createState("HeliosKWL.Bypass");
             
            //Login alle 5 Min
            setInterval(function() {
                request(Hlogin);
             }, 300000);
             
            //Datenabfrage alle 5 Sek
            setInterval(function() {
                request(Hwerte8, function (error, response, result) {
                    position_anfang = result.indexOf('v00104') + 1;
                    position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                    position_ende = position_anfang;
                    position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 3;
                    setState('HeliosKWL.Aussentemperatur', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
                });
                request(Hwerte8, function (error, response, result) {
                    position_anfang = result.indexOf('v00105') + 1;
                    position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                    position_ende = position_anfang;
                    position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 3;
                    setState('HeliosKWL.Zulufttemperatur', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
                });
                request(Hwerte8, function (error, response, result) {
                    position_anfang = result.indexOf('v00107') + 1;
                    position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                    position_ende = position_anfang;
                    position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 3;
                    setState('HeliosKWL.Ablufttemperatur', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
                });
                request(Hwerte8, function (error, response, result) {
                    position_anfang = result.indexOf('v00106') + 1;
                    position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                    position_ende = position_anfang;
                    position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 3;
                    setState('HeliosKWL.Fortlufttemperatur', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
                });
                request(Hwerte8, function (error, response, result) {
                    position_anfang = result.indexOf('v00102') + 1;
                    position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                    position_ende = position_anfang;
                    position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 0;
                    setState('HeliosKWL.Lüfterstufe', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
                });
                    request(Hwerte8, function (error, response, result) {
                    position_anfang = result.indexOf('v00101') + 1;
                    position_anfang = (typeof position_anfang == 'number' ? position_anfang : 0) + 16;
                    position_ende = position_anfang;
                    position_ende = (typeof position_ende == 'number' ? position_ende : 0) + 0;
                    setState('HeliosKWL.Betriebsart', (result.slice((position_anfang - 1), position_ende)), true, parseInt(0, 10), false);
                });
            
            }, 5000);
            
            A Offline
            A Offline
            acidsubway
            wrote on last edited by
            #44

            seid ein paar Tagen kommt das bei mir in der LOG
            764) You are assigning a string to the state "javascript.0.HeliosKWL.Betriebsart_SOLL" which expects a number. Please fix your code to use a number or change the state type to string. This warning m

            A 1 Reply Last reply
            0
            • A acidsubway

              seid ein paar Tagen kommt das bei mir in der LOG
              764) You are assigning a string to the state "javascript.0.HeliosKWL.Betriebsart_SOLL" which expects a number. Please fix your code to use a number or change the state type to string. This warning m

              A Offline
              A Offline
              acidsubway
              wrote on last edited by
              #45

              Hab den Fehler gefunden, der war nicht vom Script!

              MfG

              KLVNK 1 Reply Last reply
              0
              • A acidsubway

                Hab den Fehler gefunden, der war nicht vom Script!

                MfG

                KLVNK Offline
                KLVNK Offline
                KLVN
                wrote on last edited by
                #46

                @acidsubway said in [Gelöst] Helios KWL - Zugriff auf xml:

                Hab den Fehler gefunden, der war nicht vom Script!

                MfG

                Danke für die Rückmeldung :D

                1 Reply Last reply
                0
                • KLVNK KLVN

                  Hier ist mein Code: https://github.com/KLVN/ioBroker_Helios-KWL
                  Läuft jetzt seit fast einer Woche und ist auch in mein VIS integriert. Sollte leicht zu erweitern sein, allerdings kann ich nicht mehr auf die Datei zugreifen, in der alle Register und Werte aufgezählt sein sollen.

                  Features

                  • Werte auslesen
                  • Lüfterstufe und andere Werte setzen
                  • Vereinfachter Partybetrieb
                  • Automatisches Zurücksetzen des Filterwechsels

                  Wichtig: Es muss mindestens Node.js v12.x installiert sein! Anleitung zum Aktualisieren: https://forum.iobroker.net/topic/22867/how-to-node-js-für-iobroker-richtig-updaten

                  E Offline
                  E Offline
                  elmocito
                  wrote on last edited by
                  #47

                  @klvn
                  Richtig starkes Script.
                  Ich hab auch eine Helios und habe aktuell nur Homebridge und Loxone bei mir im Einsatz.
                  Da die Loxone Lösung, die es zur Helios gibt nicht zufriedenstellend war, überlege ich eine ioBroker Instanz hochzuziehen.
                  Frage: Hast du zufällig den Handshake zwischen ioBroker und Homebridge gemacht? Das wäre mega.

                  KLVNK 1 Reply Last reply
                  0
                  • E elmocito

                    @klvn
                    Richtig starkes Script.
                    Ich hab auch eine Helios und habe aktuell nur Homebridge und Loxone bei mir im Einsatz.
                    Da die Loxone Lösung, die es zur Helios gibt nicht zufriedenstellend war, überlege ich eine ioBroker Instanz hochzuziehen.
                    Frage: Hast du zufällig den Handshake zwischen ioBroker und Homebridge gemacht? Das wäre mega.

                    KLVNK Offline
                    KLVNK Offline
                    KLVN
                    wrote on last edited by
                    #48

                    @elmocito sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                    Frage: Hast du zufällig den Handshake zwischen ioBroker und Homebridge gemacht? Das wäre mega.

                    Moin, mit Homebridge hatte und habe ich überhaupt keinen Kontakt, sorry.

                    Und danke für den Stern bei GitHub ;)

                    K 1 Reply Last reply
                    0
                    • KLVNK KLVN

                      Moin,

                      mittlerweile sind 2 Wochen vergangen und ich wollte mich mal erkundigen, wie es so mit eurer Lüftersteuerung läuft :)
                      Ich habe in der Zeit meinen Wochenplan etwas angepasst, sodass der Lüfter nach x Minuten wieder ausgestellt wird und nicht immer exakt zu jeder angefangenen Stunde und dass er ausgestellt wird, wenn niemand Zuhause ist. Zusätzlich habe ich noch eine "Dusch-Erkennung" eingebaut, die den Lüfter startet, sobald in den letzten 5 Minuten geduscht wurde/wird - seitdem habe ich keine beschlagenen Spiegel mehr und Schimmel kann gar nicht erst ansetzen.

                      Meinen zusätzlichen Spielkram habe ich jetzt auch bei GitHub in einem gesonderten Ordner veröffentlicht: https://github.com/KLVN/ioBroker_Helios-KWL/tree/master/additionalScripts


                      • Für die Personenzählung frage ich meine Fritzbox nach den Geräten im Netzwerk ab und zähle dann die Smartphones (das mache ich aber außerhalb vom ioBroker)
                      • Die Dusche kann ich erkennen, weil ein Durchlauferhitzer verbaut ist und dieser mächtig Strom verbraucht. War der Durchschnittsverbrauch in den letzten 5 Minuten über 6kW, dann duscht (höchstwahrscheinlich) jemand und der Lüfter geht an. Das kann aber auch durch andere Verbraucher, wie mehrere Herdplatten, Haarföne, Waschmaschine, usw. ausgelöst werden.
                      M Offline
                      M Offline
                      moehre
                      wrote on last edited by
                      #49

                      @klvn

                      Ich hatte das Projekt jetzt laaange liegen lassen, hauptsächlich, da meine Helios den Geist aufgegeben hat. Jetzt schaue ich mal wieder rein und bin beeindruckt, wie du das umgesetzt hast! Vielen Dank, auch, dass du so umfangreich dokumentierst und Hilfestellung lieferst!

                      KLVNK 1 Reply Last reply
                      1
                      • M moehre

                        @klvn

                        Ich hatte das Projekt jetzt laaange liegen lassen, hauptsächlich, da meine Helios den Geist aufgegeben hat. Jetzt schaue ich mal wieder rein und bin beeindruckt, wie du das umgesetzt hast! Vielen Dank, auch, dass du so umfangreich dokumentierst und Hilfestellung lieferst!

                        KLVNK Offline
                        KLVNK Offline
                        KLVN
                        wrote on last edited by
                        #50

                        @moehre sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                        @klvn

                        Ich hatte das Projekt jetzt laaange liegen lassen, hauptsächlich, da meine Helios den Geist aufgegeben hat. Jetzt schaue ich mal wieder rein und bin beeindruckt, wie du das umgesetzt hast! Vielen Dank, auch, dass du so umfangreich dokumentierst und Hilfestellung lieferst!

                        Ich muss mich aber auch bei dir bedanken, für deine Pionierarbeit, schließlich hast du den Stein ins Rollen gebracht :D

                        M 1 Reply Last reply
                        1
                        • KLVNK KLVN

                          @moehre sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                          @klvn

                          Ich hatte das Projekt jetzt laaange liegen lassen, hauptsächlich, da meine Helios den Geist aufgegeben hat. Jetzt schaue ich mal wieder rein und bin beeindruckt, wie du das umgesetzt hast! Vielen Dank, auch, dass du so umfangreich dokumentierst und Hilfestellung lieferst!

                          Ich muss mich aber auch bei dir bedanken, für deine Pionierarbeit, schließlich hast du den Stein ins Rollen gebracht :D

                          M Offline
                          M Offline
                          moehre
                          wrote on last edited by moehre
                          #51

                          Ich bastele gerade daran, weitere xmls auszulesen. Sieht so aus. Es sind 2 console.logs mit reingekommen, damit ich folgendem Problem irgendwie auf die Schliche komme...

                          // Refresh values
                          setInterval(function () {
                            // Load and refresh values from different XML-files (default: page 4 and page 8. Can be extended from 1 to 17 to obtain everything)
                            const xmlPages = [1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17];
                            xmlPages.forEach(function (page, index) {
                              request(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"), function (error, response, result) {
                                console.log(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"))
                                refreshValues(result);
                                console.log(result);
                                });
                            });
                          }, refresh_interval * 1000);
                          

                          Das klappt bis zu 12 xmls auch super, alle weiteren werfen Fehler. Folglich bekomme ich diesen Fehler 4x:

                          javascript.0	2021-04-13 01:01:57.423	error	(549) Request error: Error: connect ECONNRESET [hier steht die IP der Helios samt Port]
                          javascript.0	2021-04-13 01:01:57.423	error	(549) Error in request callback: TypeError: Cannot read property 'matchAll' of undefined
                          

                          Laut log sieht der request gut aus, die URLs werden korrekt erstellt, die xmls existieren.
                          Es ist egal, welche page rausgenommen wird, jede Änderung der pages wird die Fehleranzahl verändern.

                          Verdacht: refreshValues wird ausgeführt, bevor eine Rückmeldung vom Webserver kommt.
                          Ich habe daher versucht, den request asynchron auszuführen - ohne Erfolg. Auch eine Verzögerung um x ms hat nichts gebracht.

                          Woran könnte der Fehler liegen?

                          P.S. Lösungsansatz, ohne das Problem wirklich zu verstehen: Man könnte request und refreshValues trennen. Sodass der request die übertragenen Werte als JSON wegschreibt. Der refreshValues würde dann nur noch bereits vorhandene Variablen hübsch machen. Damit wären Rückmeldung und Verarbeitung unabhängig voneinander. Und Fehler in der Aktualisierung der Daten ließen sich vorzeitig erkennen.

                          P.P.S. Über Sinn und Unsinn, wirklich ALLE Pages auszulesen, kann man sicher streiten :)

                          VG

                          KLVNK 1 Reply Last reply
                          0
                          • M moehre

                            Ich bastele gerade daran, weitere xmls auszulesen. Sieht so aus. Es sind 2 console.logs mit reingekommen, damit ich folgendem Problem irgendwie auf die Schliche komme...

                            // Refresh values
                            setInterval(function () {
                              // Load and refresh values from different XML-files (default: page 4 and page 8. Can be extended from 1 to 17 to obtain everything)
                              const xmlPages = [1, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17];
                              xmlPages.forEach(function (page, index) {
                                request(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"), function (error, response, result) {
                                  console.log(createHeader(helios_ip, "data/werte" + page + ".xml", "xml=/data/werte" + page + ".xml"))
                                  refreshValues(result);
                                  console.log(result);
                                  });
                              });
                            }, refresh_interval * 1000);
                            

                            Das klappt bis zu 12 xmls auch super, alle weiteren werfen Fehler. Folglich bekomme ich diesen Fehler 4x:

                            javascript.0	2021-04-13 01:01:57.423	error	(549) Request error: Error: connect ECONNRESET [hier steht die IP der Helios samt Port]
                            javascript.0	2021-04-13 01:01:57.423	error	(549) Error in request callback: TypeError: Cannot read property 'matchAll' of undefined
                            

                            Laut log sieht der request gut aus, die URLs werden korrekt erstellt, die xmls existieren.
                            Es ist egal, welche page rausgenommen wird, jede Änderung der pages wird die Fehleranzahl verändern.

                            Verdacht: refreshValues wird ausgeführt, bevor eine Rückmeldung vom Webserver kommt.
                            Ich habe daher versucht, den request asynchron auszuführen - ohne Erfolg. Auch eine Verzögerung um x ms hat nichts gebracht.

                            Woran könnte der Fehler liegen?

                            P.S. Lösungsansatz, ohne das Problem wirklich zu verstehen: Man könnte request und refreshValues trennen. Sodass der request die übertragenen Werte als JSON wegschreibt. Der refreshValues würde dann nur noch bereits vorhandene Variablen hübsch machen. Damit wären Rückmeldung und Verarbeitung unabhängig voneinander. Und Fehler in der Aktualisierung der Daten ließen sich vorzeitig erkennen.

                            P.P.S. Über Sinn und Unsinn, wirklich ALLE Pages auszulesen, kann man sicher streiten :)

                            VG

                            KLVNK Offline
                            KLVNK Offline
                            KLVN
                            wrote on last edited by
                            #52

                            @moehre sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                            refreshValues wird ausgeführt, bevor eine Rückmeldung vom Webserver kommt.

                            Das kann eigentlich nicht sein, weil request() diejenige Funktion ist, die nach eigener Beendigung refreshValues() aufruft und result überliefert.

                            Ich habe bei mir auch gerade alle XML-Seiten von 1 bis 17 durchprobiert, anfangs immer nur in Gruppen von ca. 6 Seiten, damit mein Log nicht zugemüllt wird und da gab es keine Fehler. Dann habe ich mir nochmal deine Fehlermeldung angesehen und "ECONNRESET" bedeutet, dass die Helios-Anlage die Verbindung getrennt hat. Dann habe ich nochmal dein Array an XML-Seiten genommen (also alle 16 auf einmal) und dann auch Fehlermeldungen bekommen. Meine Vermutung ist jetzt, dass die Helios-Anlage nicht zu viele Anfragen in sehr kurzer Zeit beantworten will und deshalb teilweise abbricht. Bei mir waren es auch nicht immer dieselben Seiten, bei denen abgebrochen wurde, sondern jedes Mal komplett unterschiedlich.

                            @moehre sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                            Auch eine Verzögerung um x ms hat nichts gebracht.

                            Wo und wie hast du diese Verzögerung eingebaut? Wenn man xmlPages.forEach() langsamer laufen lässt, sollte es eigentlich gehen, habe es jetzt aber auch nicht getestet. Leider gibt es auch keine einzelne XML-Seite, auf der alle Werte auf einmal sind.

                            1 Reply Last reply
                            0
                            • M Offline
                              M Offline
                              moehre
                              wrote on last edited by
                              #53

                              @klvn sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                              Wo und wie hast du diese Verzögerung eingebaut? Wenn man xmlPages.forEach() langsamer laufen lässt, sollte es eigentlich gehen, habe es jetzt aber auch nicht getestet. Leider gibt es auch keine einzelne XML-Seite, auf der alle Werte auf einmal sind.

                              Da ich mit dem async keinen Erfolg hatte, habe ich es auf die schmutzige Tour versucht:

                              // Sleep function to delay requests
                              function sleep(milliseconds) {
                                  const date = Date.now();
                                  let currentDate = null;
                                  do {
                                      currentDate = Date.now();
                                  }   while (currentDate - date < milliseconds);
                              }
                              

                              sleep() dann an verschiedenen Stellen innerhalb des request eingefügt. Habs mit Zeiten zwischen 50ms und 1000ms probiert. Allerdings bricht auch hier ab Werten von 500ms die Verbindung zur Helios ab. Nicht mit dem ECONNRESET. Hab den Fehler gerade nicht parat...
                              Ein sleep ist nicht besonders elegant, hätte aber den Zweck erfüllen müssen. Im Log sehe ich auch, dass die Anfragen mit der entsprechenden Verzögerung rausgehen - aber trotzdem die ersten 4 requests mit ECONNRESET abbrechen.

                              1 Reply Last reply
                              0
                              • H Offline
                                H Offline
                                hartwigm
                                wrote on last edited by
                                #54

                                Vielen Dank für das Script.

                                Ich konnte so alle relevanten Daten auslesen.

                                Nun stellt sich aber die Frage nach der Regelung und wäre dankbar für eure Tipps und Erfahrungen.

                                Zum System.

                                Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                                Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                                Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                                Ebenso würde ich dies mit dem Temperaturen gerne machen.

                                Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                                Geht das so? Bzw. wie macht ihr das?

                                KLVNK 1 Reply Last reply
                                0
                                • H hartwigm

                                  Vielen Dank für das Script.

                                  Ich konnte so alle relevanten Daten auslesen.

                                  Nun stellt sich aber die Frage nach der Regelung und wäre dankbar für eure Tipps und Erfahrungen.

                                  Zum System.

                                  Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                                  Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                                  Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                                  Ebenso würde ich dies mit dem Temperaturen gerne machen.

                                  Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                                  Geht das so? Bzw. wie macht ihr das?

                                  KLVNK Offline
                                  KLVNK Offline
                                  KLVN
                                  wrote on last edited by KLVN
                                  #55

                                  @hartwigm sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                  Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                                  Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                                  Weißt du bzw. hast du diese Werte schon im ioBroker?

                                  Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                                  Ebenso würde ich dies mit dem Temperaturen gerne machen.

                                  Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                                  Geht das so? Bzw. wie macht ihr das?

                                  Ich würde die Werte der Sensoren der Reihe nach abfragen, in ein Array schreiben (z.B. sensorsTemps = [19.2, 21.1, 18.6, 22]) und mir daraus das Minimum nehmen.

                                  Beispiel-/Pseudo-Code:

                                  var sensorsTemps = [];
                                  
                                  sensorsTemps[0] = getTemperature("Wohnzimmer"); // oder wie du sonst an die Werte kommst
                                  sensorsTemps[1] = getTemperature("Zimmer 1");
                                  // ...
                                  
                                  sensorsTemps = [19.2, 21.1, 18.6, 22]; // Beispiel-Daten
                                  var lowestTemp = Math.min.apply(Math, sensorsTemps);
                                  
                                  if (lowestTemp < x) {
                                    setState(datapoint_prefix + "." + datapoint_names["w00102"], 2); // aus dem Helios Skript, um "Luefterstufe_SOLL" auf Stufe 2 zu setzen
                                  }
                                  
                                  

                                  und das alles in ein Schedule/setInterval, was dann alle x Minuten die Werte abfragt und die Bedingung prüft. Für meine Badezimmer-Lüftung prüfe ich alle 3 Minuten: https://github.com/KLVN/ioBroker_Helios-KWL/blob/e844b070ebc09a1d7ebe41d01cf53c5efa11ca15/additionalScripts/bathroomVentilation.js#L21

                                  H R 2 Replies Last reply
                                  0
                                  • KLVNK KLVN

                                    @hartwigm sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                    Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                                    Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                                    Weißt du bzw. hast du diese Werte schon im ioBroker?

                                    Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                                    Ebenso würde ich dies mit dem Temperaturen gerne machen.

                                    Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                                    Geht das so? Bzw. wie macht ihr das?

                                    Ich würde die Werte der Sensoren der Reihe nach abfragen, in ein Array schreiben (z.B. sensorsTemps = [19.2, 21.1, 18.6, 22]) und mir daraus das Minimum nehmen.

                                    Beispiel-/Pseudo-Code:

                                    var sensorsTemps = [];
                                    
                                    sensorsTemps[0] = getTemperature("Wohnzimmer"); // oder wie du sonst an die Werte kommst
                                    sensorsTemps[1] = getTemperature("Zimmer 1");
                                    // ...
                                    
                                    sensorsTemps = [19.2, 21.1, 18.6, 22]; // Beispiel-Daten
                                    var lowestTemp = Math.min.apply(Math, sensorsTemps);
                                    
                                    if (lowestTemp < x) {
                                      setState(datapoint_prefix + "." + datapoint_names["w00102"], 2); // aus dem Helios Skript, um "Luefterstufe_SOLL" auf Stufe 2 zu setzen
                                    }
                                    
                                    

                                    und das alles in ein Schedule/setInterval, was dann alle x Minuten die Werte abfragt und die Bedingung prüft. Für meine Badezimmer-Lüftung prüfe ich alle 3 Minuten: https://github.com/KLVN/ioBroker_Helios-KWL/blob/e844b070ebc09a1d7ebe41d01cf53c5efa11ca15/additionalScripts/bathroomVentilation.js#L21

                                    H Offline
                                    H Offline
                                    hartwigm
                                    wrote on last edited by
                                    #56

                                    @klvn Danke

                                    Ich hatte hier auch schon ein am Freitag ein Telefonat mit dem Helios Support.

                                    Es geht nicht, dass die Werte von externen Sensoren an die Helios übergeben werden kann.
                                    Daher habe ich es, wie von dir beschrieben nun realisiert.

                                    Meine Logik habe ich dabei aber nicht im iobroker, sondern in Edomi. Die Systeme kommunizieren über mqtt.

                                    Dabei ist mir noch ein kleiner Fehler beim schreiben auf die Betriebsart oder Stufe aufgefallen.

                                    Wenn ich die Zielwerte per mqtt gesendet hab, sind diese auch unter Objekte eingetragen worden, allerdings nur sehr sporadisch ausgeführt worden. Stabil hat dies sofort funktioniert nachdem ich die Variabenart von gemischt auf Zahl umgestellt habe.

                                    Dies scheint aber nur relevant zu sein, wenn der Wert per mqtt gesetzt wird.

                                    Vielen Dank für das sehr hilfreiche Script

                                    Hartwig

                                    1 Reply Last reply
                                    0
                                    • R Offline
                                      R Offline
                                      Reliktdragon 0
                                      wrote on last edited by Reliktdragon 0
                                      #57

                                      Hallo.

                                      Danke für dieses tolle Script.
                                      Ich hätte da aber noch eine frage.

                                      Das Skript funktioniert bei mir, ich kan die Helios auch steuern.

                                      Nur im Log kommen diese ganzen fehler wenn das Skript läuft:

                                      E0C05D03-9B4C-49A3-9A6A-C48866AA069A.png

                                      Ist das normal oder habe ich was vergessen zu ändern?

                                      Edit: Hab das Script auf einer neuen Javascript Instanz laufen lassen, jetzt funktioniert es plötzlich.

                                      Grüße

                                      1 Reply Last reply
                                      0
                                      • KLVNK KLVN

                                        @elmocito sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                        Frage: Hast du zufällig den Handshake zwischen ioBroker und Homebridge gemacht? Das wäre mega.

                                        Moin, mit Homebridge hatte und habe ich überhaupt keinen Kontakt, sorry.

                                        Und danke für den Stern bei GitHub ;)

                                        K Offline
                                        K Offline
                                        knudos
                                        wrote on last edited by
                                        #58

                                        @klvn Gibt es eine Möglichkeit die Helios KWL in Hoobs einzubinden?

                                        1 Reply Last reply
                                        0
                                        • KLVNK KLVN

                                          @hartwigm sagte in [Gelöst] Helios KWL - Zugriff auf xml:

                                          Ich habe eine Helios 500 für 6 Räume einbauen lassen. In den Räume habe ich Steinel Multisensoren auf KNX, deren Werte ich für die Steuerung gerne nutzen würde.
                                          Die Steinel liefern Temperatur, Feuchte, CO2 und VOC.

                                          Weißt du bzw. hast du diese Werte schon im ioBroker?

                                          Dabei würde ich aus den Räumen jeweils den schlechtesten Co2 Wert an die Helios übergeben und damit der Helios die Steuerung überlasen.
                                          Ebenso würde ich dies mit dem Temperaturen gerne machen.

                                          Hier fehlt mir aber noch der Plan wie ich die Werte übergeben kann.

                                          Geht das so? Bzw. wie macht ihr das?

                                          Ich würde die Werte der Sensoren der Reihe nach abfragen, in ein Array schreiben (z.B. sensorsTemps = [19.2, 21.1, 18.6, 22]) und mir daraus das Minimum nehmen.

                                          Beispiel-/Pseudo-Code:

                                          var sensorsTemps = [];
                                          
                                          sensorsTemps[0] = getTemperature("Wohnzimmer"); // oder wie du sonst an die Werte kommst
                                          sensorsTemps[1] = getTemperature("Zimmer 1");
                                          // ...
                                          
                                          sensorsTemps = [19.2, 21.1, 18.6, 22]; // Beispiel-Daten
                                          var lowestTemp = Math.min.apply(Math, sensorsTemps);
                                          
                                          if (lowestTemp < x) {
                                            setState(datapoint_prefix + "." + datapoint_names["w00102"], 2); // aus dem Helios Skript, um "Luefterstufe_SOLL" auf Stufe 2 zu setzen
                                          }
                                          
                                          

                                          und das alles in ein Schedule/setInterval, was dann alle x Minuten die Werte abfragt und die Bedingung prüft. Für meine Badezimmer-Lüftung prüfe ich alle 3 Minuten: https://github.com/KLVN/ioBroker_Helios-KWL/blob/e844b070ebc09a1d7ebe41d01cf53c5efa11ca15/additionalScripts/bathroomVentilation.js#L21

                                          R Offline
                                          R Offline
                                          Ritschy2000
                                          wrote on last edited by
                                          #59

                                          @klvn kannst du mir noch einen Tip geben, wie ich:

                                          Bypass Raum/Temp. = v01035 (aus der gaer.htm) beschreiben und auslesen kann?

                                          Darüber lässt sich relativ simple der Bypass "steuern".

                                          Habe bei deinem Script schon verschiede Dinge hinzugefügt, aber irgendwie
                                          funktioniert es bei der Funktion nicht, ich bekomme den Wert nicht mal ausgelesen.
                                          Liegt es eventuell daran, dass der Wert in einem Untermenü steckt?
                                          Aber du setzt ja über dein Script auch den Filterwechsel zurück, welcher sich auf der gleichen
                                          Seite befindet.

                                          Bin für jede Hilfe dankbar.

                                          KLVNK 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          402

                                          Online

                                          32.7k

                                          Users

                                          82.3k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe