Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Panasonic Wärmepumpenmanager, Script / Ideen gesucht

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Panasonic Wärmepumpenmanager, Script / Ideen gesucht

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      sonny @ticaki last edited by

      @ticaki

      Bitteschön :
      script.js.Statische_Scripte.Wärmepumpe: http://192.168.8.165/v107000.rsp?sessionid=5A5B0295

      Eine am Deckel krieg ich aber auch :
      Screenshot 2024-01-13 145527.png

      T 1 Reply Last reply Reply Quote 0
      • T
        ticaki Developer @sonny last edited by

        @sonny

        Funktioniert die url in deinem browser?

        S 1 Reply Last reply Reply Quote 0
        • S
          sonny @ticaki last edited by

          @ticaki

          Ja, was mich wundert (Mein Computer hat ne andere IP Adresse in meinem Netzwerk als der Iobroker Raspberry, ich müsste normalerweise vom Pumpenmanager nen Tritt in den Hintern bekommen oder eine neue Session ID)

          Scheint aber zu funktionieren Siehe:

          Screenshot 2024-01-13 151332.png

          T 1 Reply Last reply Reply Quote 0
          • T
            ticaki Developer @sonny last edited by

            @sonny

            Ich füge mal unterschämt viele Debuglog einträge hinzu - 5-10 Minuten

            S 1 Reply Last reply Reply Quote 0
            • S
              sonny @ticaki last edited by

              @ticaki

              Ich stell 2 Kaffee in den Raum hier inzwischen !

              T 1 Reply Last reply Reply Quote 0
              • T
                ticaki Developer @sonny last edited by ticaki

                @sonny

                Hab den schedule eingebaut, dauert bis zur vollen Minute bevor es durchläuft.

                brauche 3 Logeinträge vor dem Fehler.

                const ip = '192.168.8.165';
                const prefix = '0_userdata.0.test'; // wird erstellt oder erweitert bei jedem durchlauf
                const channelName = 'My great channel';
                const interval = '* * * * *';
                const DEBUG = true
                
                
                const axios = require('axios');
                const { HTMLToJSON } = require('html-to-json-parser');
                
                let values: any = {};
                async function main() {
                    const result = await axios(`http://${ip}`);
                    if ( result && result.data) {
                        logDebug(`Get data from http://${ip}`);
                        logDebug(``);
                        for (const r of db) {
                            const match = result.data.match(r);
                            if (match && Array.isArray(match) && match.length >= 1) {
                                log(`http://${ip}/${match[0]}`)
                                const response = await axios(`http://${ip}/${match[0]}`);
                                if (response && response.data) {
                                    logDebug(`Get data from http://${ip}/${match[0]}`);
                                    const body = response.data.replace(/\n/gm, '').match(/<body>.*?<\/body>/gm)[0]
                                    let data
                                    try {
                                        data = await HTMLToJSON(body, false);
                                    } catch (e) {
                                        log(e)
                                    }
                                    if (data && data.type == 'body') {
                                        logDebug(`Parse data ok, found body`);
                                        let d = data.content;
                                        for (const c in d) {
                                            const v = d[c];
                                            if (v.type === 'div') {
                                                logDebug(`div found`);
                                                for (const i of v.content) {
                                                    if (i.attributes && i.attributes.class == 'dp') {
                                                        logDebug(`class db found`);
                                                        for (const b of i.content) {
                                                            if (b.type) {
                                                                logDebug(`type ${b.type} found`);
                                                                let val = b.content.join(' ').match(/ [0-9\.,]+/);
                                                                let end = '';
                                                                logDebug(val);
                                                                if (!val || isNaN(val.join(''))) val = b.content.join(' ');
                                                                else {
                                                                    end = '_' + b.content.join(' ').replace(val, '');
                                                                    val = parseFloat(val.join(''));
                                                                }
                                                                values[(b.attributes.href + end).replace(/^.*?sessionid\=[0-9A-Z]+\&id\=/, '').replace(/[^_\-/:!#$%&()+=@^{}|~\p{Ll}\p{Lu}\p{Nd}]+/gu, '_')] = val;
                                                            }
                                                        }
                                                    }
                                                }
                
                                            }
                                        }
                                    } else logDebug(`${data ? 'Parse data ok' : 'Parse data failed!'}, ${data.type == 'body' ? 'body found' : 'body not found'}`);
                                } else logDebug(`Don't get data from http://${ip}/${match[0]}`);
                            }
                        }
                    } else logDebug(`Don't get data from http://${ip}`);
                    for (const id in values) {
                        const val = values[id];
                        await extendObjectAsync(`${prefix}`,{type: 'channel', common:{name: channelName}});
                        if (!existsState(`${prefix}.${id}`)) await createStateAsync(`${prefix}.${id}`, val, {name: 'no description', role: typeof val === 'string' ? 'text' : 'value', type: typeof val, read: true, write: false})
                        await setStateAsync(`${prefix}.${id}`, val, true);
                    }
                }
                
                function logDebug(l: string): void {
                    if (DEBUG) log(l);
                }
                
                const db: RegExp[] = [
                    /v107000\.rsp\?sessionid=[0-9A-Z]+/,
                    /v21\.rsp\?sessionid=[0-9A-Z]+/,
                    /v50\.rsp\?sessionid=[0-9A-Z]+/  
                ]
                
                schedule(interval, main);
                
                S 1 Reply Last reply Reply Quote 0
                • S
                  sonny @ticaki last edited by sonny

                  @ticaki

                  Screenshot 2024-01-13 145527.png

                  Das kommt raus dabei ...

                  Hab 4 Durchläufe durch, Session ID ändert sich brav mit (Einmal pro Minute geht sich aus, mehr wie 3 Sitzungen, wo ich nicht wusste wann er die letzte "vergisst" mag er nicht)

                  Also soweit:
                  script.js.Statische_Scripte.Wärmepumpe: Get data from http://192.168.8.165/v107000.rsp?sessionid=0417D206

                  klappt es

                  T 1 Reply Last reply Reply Quote 0
                  • T
                    ticaki Developer @sonny last edited by

                    @sonny

                    Ja ich weiß wo der Fehler liegt, aber muß rumprobieren wie ich ihn behebe. die Regex kommt mit den Zeilenumbrüchen nicht klar und das entfernen sebiger hat scheinbar nicht geholfen.

                    const ip = '192.168.8.165';
                    const prefix = '0_userdata.0.test'; // wird erstellt oder erweitert bei jedem durchlauf
                    const channelName = 'My great channel';
                    const interval = '* * * * *';
                    const DEBUG = true
                    
                    
                    const axios = require('axios');
                    const { HTMLToJSON } = require('html-to-json-parser');
                    
                    let values: any = {};
                    async function main() {
                        const result = await axios(`http://${ip}`);
                        if ( result && result.data) {
                            logDebug(`Get data from http://${ip}`);
                            logDebug(``);
                            for (const r of db) {
                                const match = result.data.match(r);
                                if (match && Array.isArray(match) && match.length >= 1) {
                                    log(`http://${ip}/${match[0]}`)
                                    const response = await axios(`http://${ip}/${match[0]}`);
                                    if (response && response.data) {
                                        logDebug(`Get data from http://${ip}/${match[0]}`);
                                        let body = response.data.replace(/\n/gm, '').match(/<body>.*?<\/body>/gms)
                                        if (body || Array.isArray(body) ) {
                                            body = body[0];
                                        }
                                        if (!body) {
                                            log('Regex: Body not found', 'error');
                                            continue;
                                        }
                                        let data
                                        try {
                                            data = await HTMLToJSON(body, false);
                                        } catch (e) {
                                            log(e)
                                        }
                                        if (data && data.type == 'body') {
                                            logDebug(`Parse data ok, found body`);
                                            let d = data.content;
                                            for (const c in d) {
                                                const v = d[c];
                                                if (v.type === 'div') {
                                                    logDebug(`div found`);
                                                    for (const i of v.content) {
                                                        if (i.attributes && i.attributes.class == 'dp') {
                                                            logDebug(`class db found`);
                                                            for (const b of i.content) {
                                                                if (b.type) {
                                                                    logDebug(`type ${b.type} found`);
                                                                    let val = b.content.join(' ').match(/ [0-9\.,]+/);
                                                                    let end = '';
                                                                    logDebug(val);
                                                                    if (!val || isNaN(val.join(''))) val = b.content.join(' ');
                                                                    else {
                                                                        end = '_' + b.content.join(' ').replace(val, '');
                                                                        val = parseFloat(val.join(''));
                                                                    }
                                                                    values[(b.attributes.href + end).replace(/^.*?sessionid\=[0-9A-Z]+\&id\=/, '').replace(/[^_\-/:!#$%&()+=@^{}|~\p{Ll}\p{Lu}\p{Nd}]+/gu, '_')] = val;
                                                                }
                                                            }
                                                        }
                                                    }
                    
                                                }
                                            }
                                        } else logDebug(`${data ? 'Parse data ok' : 'Parse data failed!'}, ${data.type == 'body' ? 'body found' : 'body not found'}`);
                                    } else logDebug(`Don't get data from http://${ip}/${match[0]}`);
                                }
                            }
                        } else logDebug(`Don't get data from http://${ip}`);
                        for (const id in values) {
                            const val = values[id];
                            await extendObjectAsync(`${prefix}`,{type: 'channel', common:{name: channelName}});
                            if (!existsState(`${prefix}.${id}`)) await createStateAsync(`${prefix}.${id}`, val, {name: 'no description', role: typeof val === 'string' ? 'text' : 'value', type: typeof val, read: true, write: false})
                            await setStateAsync(`${prefix}.${id}`, val, true);
                        }
                    }
                    
                    function logDebug(l: string): void {
                        if (DEBUG) log(l);
                    }
                    
                    const db: RegExp[] = [
                        /v107000\.rsp\?sessionid=[0-9A-Z]+/,
                        /v21\.rsp\?sessionid=[0-9A-Z]+/,
                        /v50\.rsp\?sessionid=[0-9A-Z]+/  
                    ]
                    
                    schedule(interval, main);
                    

                    Jetzt gibts nicht mehr den großen Fehler sondern nur noch welche die zeigen das die Regex noch immer nicht funktioniert.

                    S 1 Reply Last reply Reply Quote 0
                    • S
                      sonny @ticaki last edited by sonny

                      @ticaki

                      Ich kann dir hier vielleicht helfen: fängst du mit Python etwas an ?
                      Es gibt jemanden aus dem Haustechnikdialog , der das mit Python geschafft hat, vermutlich eh auf gleichem Weg wie du hier:
                      Ich füg hier ein Codebeispiel ein- Eigentum "Ladyshave" aus dem Haustechnikforum. (Ist öffentlich , ich hoffe man hat nichts dagegen wenn ich mir den für Demonstrationszwecke ausborge)

                      [code]
                      ####################################################
                      # Script zum Auslesen des HPM Waermepumpenmanagers #
                      # getestete Firmware H1.1.20 vom 22.01.2015 #
                      # #
                      # programmed by ladyshave ;-) #
                      ####################################################
                      # V1.0 vom 14.03.2016 #
                      ####################################################
                      
                      import requests
                      
                      #ip-Adresse des HPM
                      website="http://192.168.101.10"
                      
                      #Auslesen der Daten und Aufbereiten
                      t = requests.get(website)
                      url = t.url
                      print (url)
                      
                      #holen der SessionID für die Sitzung
                      sessionid = url[39:47]
                      print (sessionid)
                      
                      #URLs mit SessionID basteln:
                      url_wp= "http://192.168.101.10/v21.rsp?sessionid=" + sessionid
                      url_bw= "http://192.168.101.10/v107000.rsp?sessionid=" + sessionid
                      url_pu= "http://192.168.101.10/v100100.rsp?sessionid=" + sessionid
                      url_hk1= "http://192.168.101.10/v30.rsp?sessionid=" + sessionid
                      url_hk2= "http://192.168.101.10/v3.rsp?sessionid=" + sessionid
                      
                      #Daten der Seiten abholen
                      daten_wp = requests.get(url_wp)
                      daten_bw = requests.get(url_bw)
                      daten_pu = requests.get(url_pu)
                      daten_hk1 = requests.get(url_hk1)
                      daten_hk2 = requests.get(url_hk2)
                      
                      #Test Augabe der Website als Text
                      #print (daten_wp.text)
                      #print (daten_bw.text)
                      #print (daten_pu.text)
                      #print (daten_hk1.text)
                      #print (daten_hk2.text)
                      
                      #Funktion zum Auslesen der Daten aus der Seite
                      def daten_lesen(text, suchstring, bezeichnung):
                      index = text.find(suchstring) #Anfangsindex im String suchen
                      indexend = text.find("</a>", index) #Endindex im String suchen
                      #print (index)
                      #print (indexend)
                      if index == -1:
                      return -1
                      index = index + 14 #Index nach ID setzen
                      i=0
                      rueckgabe=""
                      laenge = indexend-index #laenge des Index berechnen
                      while i != laenge: #Schleife ueber laenge
                      # falls Zahl im Namen wird dies mit isalpaha() ausgeblendet
                      # ansonsten Zahl oder "." oder "-"schreiben
                      if text[index + i-1].isalpha() == False and (text[index + i].isdigit() == True or text[index + i] == "." or text[index + i] == "-"):
                      rueckgabe = rueckgabe + text[index + i]
                      i = i + 1 #naechter bitte
                      return (bezeichnung + ":" + rueckgabe) #Rueckgabe des Textes
                      
                      #id=126:6.6.22">Freq 0</a>
                      #id=110:6.6.5">SollwertBW 2 °C
                      #id=109:6.6.4">SollwertHK 2 °C</a>
                      #Vorlauf id=111:6.6.6"> 29 °C</a>
                      #Ruecklauf id=112:6.6.7"> 29 °C</a>
                      print (daten_lesen (daten_wp.text, "id=126:6.6.22", "WP_Freq"))
                      print (daten_lesen (daten_wp.text, "id=110:6.6.5", "WP_SollBW"))
                      print (daten_lesen (daten_wp.text, "id=109:6.6.4", "WP_SollHK"))
                      print (daten_lesen (daten_wp.text, "id=111:6.6.6", "WP_Vorl"))
                      print (daten_lesen (daten_wp.text, "id=112:6.6.7", "WP_Rueckl"))
                      
                      #Pufferdaten auslesen:
                      #Istwert id=61:6.5.5"> 32.0 °C</a>
                      #Sollwert id=59:6.5.3">SW-Zone1 32.4 °C</a>
                      print (daten_lesen (daten_pu.text, "id=61:6.5.5", "PU_Istwert"))
                      print (daten_lesen (daten_pu.text, "id=59:6.5.3", "PU_Sollwert"))
                      
                      #Brauchwasser:
                      #Istwertid=38:6.4.8"> 42.0 °C</a>
                      #Sollwertid=37:6.4.7">SW-Spei 45.0 °C</a>
                      print (daten_lesen (daten_bw.text, "id=38:6.4.8", "BW_Istwert"))
                      print (daten_lesen (daten_bw.text, "id=37:6.4.7", "BW_Sollwert"))
                      
                      #HK1
                      #Istwert id=13:6.2.12"> 22.7 °C</a>
                      #Sollwert id=12:6.2.11">SW-Vorl 30.9 °C</a>
                      #Ausstemp id=9:6.2.8"> 2.0 °C</a>
                      print (daten_lesen (daten_hk1.text, "id=13:6.2.12", "HK1_Istwert"))
                      print (daten_lesen (daten_hk1.text, "id=12:6.2.11", "HK1_Sollwert"))
                      print (daten_lesen (daten_hk1.text, "id=9:6.2.8", "HK1_Aussen"))
                      
                      #HK2
                      #Istwert id=27:6.3.12"> 30.7 °C</a>
                      #Sollwert id=26:6.3.11">SW-Vorl 31.0 °C</a>
                      print (daten_lesen (daten_hk2.text, "id=27:6.3.12", "HK2_Istwert"))
                      print (daten_lesen (daten_hk2.text, "id=26:6.3.11", "HK2_Sollwert"))
                      [/code]
                      

                      und hier ein Forumsbeitrag, sehr versprechend, mit selbigem Projekt: Da gabs ne Lösung dazu (aus der ich natürlich absolut nicht schlau werd)
                      https://www.loxforum.com/forum/german/software-konfiguration-programm-und-visualisierung/35354-web-interface-einer-panasonic-lwp-mit-hpm-über-virtuelle-http-eingänge-einlesen

                      Die Infos hab ich in vergangenheit zusammengekrazt, es war alles was ich finden konnte darüber

                      LG und danke derweil für alles !

                      Screenshot 2024-01-13 145527.png

                      T 1 Reply Last reply Reply Quote 0
                      • T
                        ticaki Developer @sonny last edited by ticaki

                        @sonny
                        Erstmal kann ich python nicht leiden und die Arbeit mache ich mir für einen Adapter und dann bis du das Opfer 😄

                        bitte probiere noch meinen Code aus ich will das mit der RegEx noch probieren (vorheriger Beitrag) wenn nicht klappt mache ich es auf dem langweiliigen weg.

                        EDIT: gehts?

                        S 1 Reply Last reply Reply Quote 0
                        • S
                          sonny @ticaki last edited by

                          @ticaki

                          Moment ich hab das Script gerade gestartet, der Ordner wurde erstellt.
                          Ich gleich das eben ab und "suche" nach fehler 🙂 Das Log wird halt überfüllt, das unmengen "gefunden" wurde .aber Infos, keine Fehler.

                          Opfer immer gern, für die Entwicklung sowieso. Soll ja jedem helfen.

                          T 2 Replies Last reply Reply Quote 0
                          • T
                            ticaki Developer @sonny last edited by

                            @sonny

                            Dann mache DEBUG=false Dann hält es die klappe 🙂

                            Wenn du einen Adapter haben möchtest trage bitte sorgfällig englische Bezeichnungen in das Namenfeld der Objekte ein. (stift rechts klicken) Wenn du das hast exportiere den ganze Ordner und stelle ihn hier ein.

                            S 1 Reply Last reply Reply Quote 0
                            • S
                              sonny @ticaki last edited by

                              @ticaki

                              Du ich glaub das funktioniert !!!

                              Screenshot 2024-01-13 145527.png

                              So z.b ?

                              Für mich extra brauchst keinen machen. Ich glaub auch nicht, das den jemals jemand braucht- Das Script sollte reichen.
                              Wenn du allerdings willst, mach ich das gern. (Bin eigentlich eh grad dabei, was ich weiß geb ich einen Namen)

                              Ich tests mal kommende Tage auf Herz und Nieren. Sieht MOMENTAN aber alles wunderbar aus hey !

                              T 1 Reply Last reply Reply Quote 1
                              • T
                                ticaki Developer @sonny last edited by

                                @sonny

                                und wenn alles geht kannst du das

                                log(`http://${ip}/${match[0]}`)
                                

                                auskommentieren:

                                //log(`http://${ip}/${match[0]}`)
                                
                                1 Reply Last reply Reply Quote 0
                                • T
                                  ticaki Developer @sonny last edited by

                                  @sonny sagte in Panasonic Wärmepumpenmanager, Script / Ideen gesucht:

                                  Für mich extra brauchst keinen machen. Ich glaub auch nicht, das den jemals jemand braucht- Das Script sollte reichen.
                                  Wenn du allerdings willst, mach ich das gern. (Bin eigentlich eh grad dabei, was ich weiß geb ich einen Namen)

                                  Ist dein Gerät hier dabei, oder mit denen kompatibel?
                                  https://github.com/search?q=repo%3AioBroker%2FAdapterRequests+Panasonic&type=issues

                                  S 1 Reply Last reply Reply Quote 0
                                  • S
                                    sonny @ticaki last edited by sonny

                                    @ticaki

                                    Moment ich brauch ein bissl ich schau mir das an, ob diese Wärmepumpe vom Pumpenmanager Unterstützt wird.
                                    Ich kann dir, vorrausgesetzt man HAT diesen Pumpenmanager und entsprechendes Adapterkabel von Panasonic , die Liste der unterstützten Geräte hier posten....

                                    Für Google: Das Geräte heißt: Panasonic PAW-HPM oder PAW-HPM1 (Das sich Leute hierher verlaufen)

                                    Screenshot 2024-01-13 145527.png

                                    Alle anderen Requests, Seitens Wärmepumpen: sind beim Projekt: HEISHAMON besser aufgehoben.
                                    Was der HPM kann, kann Heishamon nicht und umgekehrt .

                                    Wir handeln hier die Generationen ab, die Heishamon NICHT kann (und vermutlich auch nie können wird- Anderes Kommunikationsprotokoll) - Aber auch älter sind, aber von den Kübeln sind noch genug im Umlauf.
                                    Ich hatte Heishamon an meiner Probiert, keine Chance, daher den HPM gekauft. Es sind immer mal wieder auf Ebay Kleinanzeigen, welche zu gutem Kurs zu bekommen.

                                    Ich geb hier alles mal einen Namen, mach meine Datenbank fertig- und werd kommende Tage schaun ob alles passt (Ich nehm aber an ja, würde ja jetzt schon Probleme geben denk ich).

                                    Nächste Woche möcht ich mich noch wegen paar Kisten Bier oder was auch immer du gerne hättest, was ich dir schuldig bin, unterhalten 🙂 - Ich sag in jedem Fall : Tausend dank derweil !- Ich meld mich hier sollte es Probleme geben, und in jedem Fall Dienstag/Mittwoch und sorge für ein selbstverständliches entgegenkommen meinerseits .

                                    LG

                                    S 1 Reply Last reply Reply Quote 0
                                    • S
                                      sonny @sonny last edited by sonny

                                      @ticaki

                                      Einen Schönheitsfehler hab ich bisher gefunden (Sonst scheint das wirklich bisher ohne Probleme zu laufen !).

                                      Sonderzeichen. Aussentemperatur wird mir als : "-1.1 �C"
                                      angezeigt und gespeichert. Was Grad Celsius " °C" sein soll nehm ich an.

                                      statt eines "ö" wird als "�" dargestellt (Störung z.b) , vermutlich Zeichensatzproblem ?
                                      Hab eben gesehen, das bei deinem Screenshot von den States, das "ö" zumindest richtig dargestellt wird. Komisch, hab ich hier Blödsinn bei mir beinander ?

                                      T 1 Reply Last reply Reply Quote 0
                                      • T
                                        ticaki Developer @sonny last edited by ticaki

                                        @sonny im Wert wird kein - dargestellt imho müsste die Temperatur aktuell im State sein. Bitte ein Bild davon.

                                        S 1 Reply Last reply Reply Quote 0
                                        • S
                                          sonny @ticaki last edited by sonny

                                          @ticaki

                                          Naja es hat ja Die Temperatur, Die 1,5 Grad minus stimmen ja

                                          Schau hier siehst es , das "ö" (Störung) und "Grad Celsius" Zeichenproblem

                                          Screenshot 2024-01-13 184614.png

                                          hab am Raspi mit "locale" nachgeschaut, von da sollt alles passen.

                                          Das versucht er darzustellen:
                                          Screenshot 2024-01-13 184845.png

                                          T 1 Reply Last reply Reply Quote 0
                                          • T
                                            ticaki Developer @sonny last edited by

                                            @sonny
                                            Jo passt, wenn du guckst sind alles Zahlen nur das ist eine Zeichenkette. folgendes bitte Anpassen:

                                            suche nach: / [0-9\.,]+/ und ersetze durch / [0-9\-.,]+/

                                            State bitte auch löschen sonst gibts warnungen.

                                            S 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            502
                                            Online

                                            31.6k
                                            Users

                                            79.5k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            74
                                            3917
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo