Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Adapter "smartmeter"

    NEWS

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    Adapter "smartmeter"

    This topic has been deleted. Only users with topic management privileges can see it.
    • R
      ralalla last edited by

      Ja poste morgen mal ein paar Bilder von Diagrammen. Aber ärgerlich das man nicht sieht wann eingespeist wird und wann bezogen wird [emoji53]

      Hab eigene Zähler mit S0 Impulsen laufen die ich rauswerfen wollte. Damit konnte ich auch alles was der eHZ macht. Vorteil ist der Zählerstand den man nun auslesen kann.

      Gesendet von iPhone mit Tapatalk

      1 Reply Last reply Reply Quote 0
      • apollon77
        apollon77 last edited by

        Naja, vllt mit den Skripten oben die Differenzen der Zählerstände ausrechnen, damit siehst Du die Unterschiede und damit die Differenz und auch wo Sie ist (1.8.0 oder 2.8.0) … vllt ne Idee

        1 Reply Last reply Reply Quote 0
        • apollon77
          apollon77 last edited by

          0.2.5 auf GitHub … ich hab mal das Speichermanagement vereinfacht an einer Stelle ... wenn es immer noch passiert muss ich weiter schauen 🙂

          1 Reply Last reply Reply Quote 0
          • S
            simpixo last edited by

            @apollon77:

            0.2.5 auf GitHub … ich hab mal das Speichermanagement vereinfacht an einer Stelle ... wenn es immer noch passiert muss ich weiter schauen 🙂 `

            Hab den Adapter aktualisiert und werde jetzt beobachten! Werde denke ich morgen schon mehr wissen

            Gruß

            Adrian

            Gesendet von iPad mit Tapatalk Pro

            1 Reply Last reply Reply Quote 0
            • apollon77
              apollon77 last edited by

              Ich hatte wieder SIGABRTs 😞 Also nächste Runde 🙂

              Lasse es jetzt mal im Vollen debug laufen und das Log spammen … vllt sieht man ja so noch irgendwas z.B. wo er das problem hat.

              Ansonsten muss ich fürchte nochmal in die SML-Library reinschauen ob nicht da was im argen ist

              Wenigstens ins der neustart-mechanismus von iobroker stabil sodass effektiv maximal ein Wert fehlt ... nur das im Log ist blöd 😉

              1 Reply Last reply Reply Quote 0
              • R
                ralalla last edited by

                So sieht dann z.B. der Verlauf des aktuellen Bezuges aus.

                1110_unbenannt.jpg

                Mit dem Skript rechne ich, wie vorgeschlagen, die Verbräuche aus.

                Fehler beim auslesen mit dem Kopf von Udo gibt es bisher keine, lese alle 10 Sekunden.

                1 Reply Last reply Reply Quote 0
                • apollon77
                  apollon77 last edited by

                  @ralalla:

                  Fehler beim auslesen mit dem Kopf von Udo gibt es bisher keine, lese alle 10 Sekunden. `

                  Auch im Log hast Du kein SIGABRT oder SIGSEGV mit Adapter-Neustarts? Was für System und was node-Version?

                  1 Reply Last reply Reply Quote 0
                  • S
                    simpixo last edited by

                    Also ich hatte seit gestern auch keinen einzigen Ausfall [emoji848]

                    Komisch ist das schon und ich lese alle 0 Sekunden! Vielleicht liegt es ja nicht am Adapter sondern an anderen Einflüssen

                    Gruß

                    Adrian

                    Gesendet von iPhone mit Tapatalk Pro

                    1 Reply Last reply Reply Quote 0
                    • apollon77
                      apollon77 last edited by

                      Super zu wissen! Danke

                      Ich hab gerade mit der Library und zeug einen test laufen und da stürzt er auch nicht ab … versuche das später malauf meinem cubietruck und als letzte Idee hab ich die Nachricht an sich im Verdacht ... vllt passt da dann und wann mal was nicht vom lesen her. Das ist die letzte idee.

                      Bitte weiter beobachten und berichten !

                      Danke. Kriegen wir schon noch stabil 🙂

                      1 Reply Last reply Reply Quote 0
                      • C
                        chemieka last edited by

                        So nun isses so weit in bin auch dabei.

                        Wir ihr sehen könnt kommen Daten rein und ich konnte auch einen Chart des aktuellen Verbrauchs anstellen.

                        Eine Frage bleibt mir aber. Das Ding sollte einen Monats und Tagesverbrauch ausspucken können, dort reicht mir die Zahl.

                        Schaut aber nicht so aus als kommen die Zahlen rein.

                        Dazu eine Idee hier in der Runde?

                        1867_strom.jpg
                        1867_strom1.jpg

                        Ich kann mir mit der Taschenlampe allerdings des Tagesverbrauch und auch den 30 Tageverbrauch anschauen. Bekommt man die Daten dort ausgelesen?

                        1 Reply Last reply Reply Quote 0
                        • S
                          simpixo last edited by

                          @apollon77:

                          Super zu wissen! Danke

                          Ich hab gerade mit der Library und zeug einen test laufen und da stürzt er auch nicht ab … versuche das später malauf meinem cubietruck und als letzte Idee hab ich die Nachricht an sich im Verdacht ... vllt passt da dann und wann mal was nicht vom lesen her. Das ist die letzte idee.

                          Bitte weiter beobachten und berichten !

                          Danke. Kriegen wir schon noch stabil 🙂 `

                          Zu früh gefreut…. [emoji30]

                          ~~![](</s><URL url=)<link_text text="https://uploads.tapatalk-cdn.com/201702 ... b33277.jpg">https://uploads.tapatalk-cdn.com/20170207/40e0e9e45a18dbe9b1bd010b75b33277.jpg</link_text>" />

                          Jetzt kam leider wieder der SIGSEGV Fehler [emoji24][emoji30]~~

                          1 Reply Last reply Reply Quote 0
                          • apollon77
                            apollon77 last edited by

                            @chemieka:

                            Ich kann mir mit der Taschenlampe allerdings des Tagesverbrauch und auch den 30 Tageverbrauch anschauen. Bekommt man die Daten dort ausgelesen? `

                            Naja … alles was rauskommt, kommt in ioBroker rein. Bedeutet (und das haben schon mehrere andere verifiziert) das diese Daten wohl über die IR-Schnittstelle nicht ausgegeben werden.

                            Aber ioBroker wäre ja nicht ioBroker wenn man das nicht skripten könnte. Sie weitere oben im Thread sind coole JavaScriptchen die genau diese Dinge tun :-)) Also: workaround ist oben 🙂

                            @simpixo: Ich hab heute auf meinem Arbeitsrechner den ganzen Tag die Library mit nem simulierten Serialport und so laufen gehabt und alles war perfekt und nichts ist gecrasht. Aber naja wir schauen mal weiter.

                            Am Ende ist aber wie oben geschrieben: Ausser hier und da ein "nerviger Logeintrag irgendwie ja alles super ... oder ?! 😉

                            1 Reply Last reply Reply Quote 0
                            • a200
                              a200 last edited by

                              @chemieka schau dir mal mein Script weiter oben. Damit werden datenpunkte für Stunde Tag Woche und Monat erzeugt.

                              1 Reply Last reply Reply Quote 0
                              • S
                                simpixo last edited by

                                @apollon77:

                                @chemieka:

                                Ich kann mir mit der Taschenlampe allerdings des Tagesverbrauch und auch den 30 Tageverbrauch anschauen. Bekommt man die Daten dort ausgelesen? `

                                Naja … alles was rauskommt, kommt in ioBroker rein. Bedeutet (und das haben schon mehrere andere verifiziert) das diese Daten wohl über die IR-Schnittstelle nicht ausgegeben werden.

                                Aber ioBroker wäre ja nicht ioBroker wenn man das nicht skripten könnte. Sie weitere oben im Thread sind coole JavaScriptchen die genau diese Dinge tun :-)) Also: workaround ist oben 🙂

                                @simpixo: Ich hab heute auf meinem Arbeitsrechner den ganzen Tag die Library mit nem simulierten Serialport und so laufen gehabt und alles war perfekt und nichts ist gecrasht. Aber naja wir schauen mal weiter.

                                Am Ende ist aber wie oben geschrieben: Ausser hier und da ein "nerviger Logeintrag irgendwie ja alles super ... oder ?! 😉 `

                                Ja klar ist alles super, ist halt nur ein klitzekleines kosmetisches Problem [emoji6]

                                Das wird mich auch nicht dran hindern den Adapter zu benutzen!!! Ist genau das was ich schon die ganze Zeit haben wollte! Jetzt muss ich nur noch was für den Gaszähler was finden

                                Ich werde mal dann einfach das Intervall einfach höher setzen und dann läuft dieser ohne Probleme durch!

                                Gesendet von iPhone mit Tapatalk Pro

                                1 Reply Last reply Reply Quote 0
                                • C
                                  chemieka last edited by

                                  @a200:

                                  @chemieka schau dir mal mein Script weiter oben. Damit werden datenpunkte für Stunde Tag Woche und Monat erzeugt. `

                                  Das wären dann aber recherische Werte die aus den Momentanwert kommen. Also nicht aus dem Gerät?

                                  Natürlich sehr Schade wenn das so ist. Kannst du kurz schreiben was ich mit dem Script genau machen muss, ich bin bis jetzt mit so etwas nicht in Berührung gekommen. Damit die Daten dann auch representativ sind wie oft müsste ich auslesen lassen?

                                  1 Reply Last reply Reply Quote 0
                                  • a200
                                    a200 last edited by

                                    @chemieka:

                                    @a200:

                                    @chemieka schau dir mal mein Script weiter oben. Damit werden datenpunkte für Stunde Tag Woche und Monat erzeugt. `

                                    Das wären dann aber recherische Werte die aus den Momentanwert kommen. Also nicht aus dem Gerät?

                                    Natürlich sehr Schade wenn das so ist. Kannst du kurz schreiben was ich mit dem Script genau machen muss, ich bin bis jetzt mit so etwas nicht in Berührung gekommen. Damit die Daten dann auch representativ sind wie oft müsste ich auslesen lassen? `

                                    @chemieka:

                                    Damit die Daten dann auch representativ sind wie oft müsste ich auslesen lassen? `

                                    • Für stündliche Statistik - 1 x pro Stunde
                                    Für tägliche Statistik - 1 x pro Tag
                                    
                                    Für wöchentliche Statistik - 1 x pro Woche
                                    
                                    Für monatliche Statistik - 1 x pro Monat 
                                    

                                    🙂

                                    Also nach meinen Informationen, kannst du zwar durch das Blinken verschiedene Werte abrufen, diese werden aber ausschließlich im Display angezeigt und nicht als Datenpaket gesendet.

                                    Jetzt mal zum meinem Skript. Ich erklär das am Beispiel des Tageswertes.

                                    Jeden Tag um 23:59 (Man könnte das auch auf die Spitze treiben und es um 23:59:59 starten) wird der aktueller Gesamtverbrauch in den Datenpunkt "javascript.0.Stromzähler.Hager.tmp.Total-d" gespeichert. Diesen Wert speichere ich persönlich noch in der DB. Muss aber nicht sein. Der Wert Gleichzeitig wird die Differenz zwischen den letzten und dem aktuellen Eintrag in diesem Datenpunkt berechnet. Gesamt(aktuell) - Gesamt(letztens) = Tagesverbrauch. Dieser Tagesverbrauch, als relativer Wert, wird in den Datenpunkt "javascript.0.Stromzähler.Hager.Day" gespeichert.

                                    Das ist Alles. Im ".Total-d" habe ich den absoluten Wert des Zählers am Ende jeden Tages. Was mir auch erlaubt nachträglich Berechnungen durchzuführen).

                                    Im ".Day" habe ich den relativen Verbrauchswert am Ende jeden Tages. Woraus ich eine Tagesverbrauchskurve erstellen kann.

                                    Das Gleich wird von meinem Skript stündlich, täglich, wöchentlich und monatlich gemacht. Die Datenmenge, die in der DB gespeichert werden ist dann entsprechend mehr oder weniger hoch, allerdings übersichtlich.

                                    • minütlich: 525600 pro Jahr
                                    stündlich: 8760 pro Jahr
                                    
                                    täglich: 365 pro Jahr
                                    
                                    wöchentlich: 52 pro Jahr
                                    
                                    monatlich 12 pro Jahr. 
                                    

                                    Da ich zusätzlich den Gesamtverbrauch (Wert aus smartmeter) minütlich speichere, bin ich in der Lage mittels SQL auch Andere Punkte zu berechnen. Was aber, wenn man auf die minütliche Auswertung verzichtet, nicht machen muss.

                                    Melde dich, falls du noch weitere Fragen an mich hast

                                    Aktuelle Version:

                                    ! ````
                                    // NEU - Zählerstand vom Anfang der akt. Stunde wird ermittelt
                                    //
                                    ! var cronH = "0 * * * *";
                                    var cronD = "59 23 * * *";
                                    var cronW = "0 0 * * 1";
                                    var cronM = "0 0 1 * ";
                                    ! var idHAGTotH = "javascript.0.Stromzähler.Hager.tmp.Total-h";
                                    var idHAGTotD = "javascript.0.Stromzähler.Hager.tmp.Total-d";
                                    var idHAGTotW = "javascript.0.Stromzähler.Hager.tmp.Total-w";
                                    var idHAGTotM = "javascript.0.Stromzähler.Hager.tmp.Total-m";
                                    var idHAGTotal = "smartmeter.0.1-0:1_8_0
                                    255.value"; /Stromverbrauch insgesammt/
                                    var idHAGZielH = "javascript.0.Stromzähler.Hager.Hour";
                                    var idHAGZielD = "javascript.0.Stromzähler.Hager.Day";
                                    var idHAGZielW = "javascript.0.Stromzähler.Hager.Week";
                                    var idHAGZielM = "javascript.0.Stromzähler.Hager.Month";
                                    var debug = false;
                                    ! var DPArray = [idHAGTotH, idHAGTotD , idHAGTotW, idHAGTotM, idHAGZielH, idHAGZielD, idHAGZielW, idHAGZielM];
                                    var DPUnit = "kWh";
                                    ! DPArray.forEach(function(wert, index, array) {
                                    var DPType = wert.split(".");
                                    var DPDescr = "Power consumption of " + (DPType[DPType.length - 1]);

                                    if(index > 3) DPUnit = "Wh";
                                    createState(wert, 0, {
                                        name: DPDescr,
                                        desc: DPDescr,
                                        type: 'number',
                                        unit: DPUnit,
                                        role: 'value'
                                    });
                                    

                                    });

                                    ! function haupt (VorId, ZielId) {
                                    var nVorwert = getState(VorId).val;
                                    var nAktuell = getState(idHAGTotal).val;
                                    var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100;
                                    setState(ZielId, nDiff, true);
                                    if(debug) log("Aus: " + nAktuell +" - "+ nVorwert + " = " + nDiff);
                                    var shandler = on ({id: ZielId, change: 'any'}, function(data) {
                                    setState(VorId, (nAktuell*10)/10, true);
                                    unsubscribe(shandler);
                                    });
                                    }
                                    ! // regelmässige Wiederholungen
                                    // -----------------------------------------------------------------------------
                                    ! schedule(cronH, function () {
                                    haupt(idHAGTotH, idHAGZielH);
                                    });
                                    schedule(cronD, function () {
                                    haupt(idHAGTotD, idHAGZielD);
                                    });
                                    schedule(cronW, function () {
                                    haupt(idHAGTotW, idHAGZielW);
                                    });
                                    schedule(cronM, function () {
                                    haupt(idHAGTotM, idHAGZielM);
                                    });
                                    ! ````

                                    Viel Spaß,

                                    a200.

                                    1 Reply Last reply Reply Quote 0
                                    • C
                                      chemieka last edited by

                                      Ok das hört sich gut an. Auf welche Zeit hast du im Adapter gestellt?

                                      Meinst du, du kannst mir erklären wo ich das Skript einfügen muss und wie ich es in Betrieb bekomme?

                                      Würde dann heute Abend versuchen wollen das Skript in Betrieb zu bekommen.

                                      Wäre dir wirklich sehr dankbar.

                                      Ach und einen zweiten Zählen für meine WP sollte kein Problem sein denke ich mal oder?

                                      1 Reply Last reply Reply Quote 0
                                      • apollon77
                                        apollon77 last edited by

                                        @chemieka:

                                        Ach und einen zweiten Zählen für meine WP sollte kein Problem sein denke ich mal oder? `

                                        Ich habe auch 2 Zähler. Nur dann - wenn Du beides z.B. per USB dran hast - solltest Du den Devices zusätzlich eindeutigen namen geben z.B. anhandf der USB-Chip Seriennnummer oder so, weil es sonst bei einem Reboot vorkommen kann das sich die ttyUSBx-Namen "tauschen" und dann hast Du Zahlenchaos 🙂

                                        Wie das für deinen lesekopf und System geht must du rausfinden. Bei Udo's Kopf steht das auf der weiter oben verlinkten Seite für Linux

                                        1 Reply Last reply Reply Quote 0
                                        • R
                                          ralalla last edited by

                                          Du musst den Javascript Adapter installieren.

                                          Dann hast du im iobroker.Admin einen neuen Reiter Namens Skripte.

                                          Dort legst du unter common ein neues Skript an und fügst den Code ein.

                                          In der Zeile 13 musst du noch deinen Datenpunkt (also wo der Zählwert her kommt) anpassen.

                                          (ggf. Zeilen 9 - 17 anpassen vom Namen her, muss spätestens beim 2. Skript gemacht werden weil ja dafür neue Datenpunkte gebraucht werden).

                                          Dann speichern und das Skript starten.

                                          Wenn im Log kein Fehler erscheint sollten die Objekte angelegt werden und nach 2 Stunden der erste Stundenwert zu sehen sein.

                                          Dran denken die Objekte dann zu speichern.

                                          1 Reply Last reply Reply Quote 0
                                          • a200
                                            a200 last edited by

                                            @chemieka:

                                            Ok das hört sich gut an. Auf welche Zeit hast du im Adapter gestellt?

                                            Meinst du, du kannst mir erklären wo ich das Skript einfügen muss und wie ich es in Betrieb bekomme?

                                            Würde dann heute Abend versuchen wollen das Skript in Betrieb zu bekommen.

                                            Wäre dir wirklich sehr dankbar. `
                                            Kein Thema.

                                            1. (Falls noch nicht geschehen) javascript Adapter aktivieren

                                            2. (Falls noch nicht geschehen) In der oberen Leiste auf den Bleistift klicken und über Show Javascript-Tab aktivieren

                                            3. Neues Skript erstellen (oben links neues Blatt-Icon) und auf Typ (oben rechts) Javascript ändern.

                                            4. Per cut & paste mein Skript reinkopieren. Namen Vergeben, Speichern.

                                            5. In dem Tab "Objects" gehen und die Stelle finden wo dein smartmeter den Gesamtwert schreibt sollte in etwa so aussehen: "smartmeter.0.1-0:1_8_0*255.value"

                                            6. Falls der Wert bei dir von meinem abweicht, dann die Zeile:

                                            var idHAGTotal      = "smartmeter.0.1-0:1_8_0*255.value"; 
                                            

                                            anpassen.

                                            7. Im Tab "Javascript" auf den "play"-Button klicken - Damit wird das Skript aktiv.

                                            Das wars. Zur nächsten vollen Stunde sollten die Datenpunkte unter "javascript.0.Stromzähler.Hager" angelegt werden. Da ein Sinnvoller Wert erst ab den Zweiten Aufruf erzeugt werden kann, wird der korrekter Wert deines Stundenverbrauchs erst nach der nächsten vollen Stunde geschrieben.

                                            Falls du Fragen hast, dann weißt du, wo du mich erreichen kannst! ;D

                                            ! ````
                                            // Datenpunkte für die Auswertung des Stromverbrauchs

                                            var cronH = "0 * * * *";
                                            var cronD = "59 23 * * *";
                                            var cronW = "0 0 * * 1";
                                            var cronM = "0 0 1 * *";

                                            ! var idHAGTotH = "javascript.0.Stromzähler.Hager.tmp.Total-h";
                                            var idHAGTotD = "javascript.0.Stromzähler.Hager.tmp.Total-d";
                                            var idHAGTotW = "javascript.0.Stromzähler.Hager.tmp.Total-w";
                                            var idHAGTotM = "javascript.0.Stromzähler.Hager.tmp.Total-m";
                                            var idHAGTotal = "smartmeter.0.1-0:1_8_0*255.value"; /Stromverbrauch insgesammt/
                                            var idHAGZielH = "javascript.0.Stromzähler.Hager.Hour";
                                            var idHAGZielD = "javascript.0.Stromzähler.Hager.Day";
                                            var idHAGZielW = "javascript.0.Stromzähler.Hager.Week";
                                            var idHAGZielM = "javascript.0.Stromzähler.Hager.Month";
                                            var debug = false;
                                            ! var DPArray = [idHAGTotH, idHAGTotD , idHAGTotW, idHAGTotM, idHAGZielH, idHAGZielD, idHAGZielW, idHAGZielM];
                                            var DPUnit = "kWh";
                                            ! DPArray.forEach(function(wert, index, array) {
                                            var DPType = wert.split(".");
                                            var DPDescr = "Power consumption of " + (DPType[DPType.length - 1]);

                                            if(index > 3) DPUnit = "Wh";
                                            createState(wert, 0, {
                                                name: DPDescr,
                                                desc: DPDescr,
                                                type: 'number',
                                                unit: DPUnit,
                                                role: 'value'
                                            });
                                            

                                            });

                                            ! function haupt (VorId, ZielId) {
                                            var nVorwert = getState(VorId).val;
                                            var nAktuell = getState(idHAGTotal).val;
                                            var nDiff = ((nAktuell * 10) - (nVorwert * 10)) * 100;
                                            if(nVorwert > 0) setState(ZielId, nDiff, true); // keinen Wert berechnen, wenn der Vorwert 0 ist.
                                            if(debug) log("Aus: " + nAktuell +" - "+ nVorwert + " = " + nDiff);
                                            var shandler = on ({id: ZielId, change: 'any'}, function(data) {
                                            setState(VorId, (nAktuell*10)/10, true);
                                            unsubscribe(shandler);
                                            });
                                            }
                                            ! // regelmässige Wiederholungen
                                            // -----------------------------------------------------------------------------
                                            ! schedule(cronH, function () {
                                            haupt(idHAGTotH, idHAGZielH);
                                            });
                                            schedule(cronD, function () {
                                            haupt(idHAGTotD, idHAGZielD);
                                            });
                                            schedule(cronW, function () {
                                            haupt(idHAGTotW, idHAGZielW);
                                            });
                                            schedule(cronM, function () {
                                            haupt(idHAGTotM, idHAGZielM);
                                            });

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            773
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            279
                                            3620
                                            1703347
                                            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