Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Msg payload string wert extrahieren

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Msg payload string wert extrahieren

    This topic has been deleted. Only users with topic management privileges can see it.
    • Jey Cee
      Jey Cee Developer last edited by

      msg.payload=msg.payload.ENERGY.Power;
      

      Damit müsste es gehen.

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

        Hallo

        Geht leider nicht kommt dies im debug

        "TypeError: Cannot read property 'Power' of undefined"

        Die Daten kommen per mqtt zu nod-red

        Ines

        1 Reply Last reply Reply Quote 0
        • G
          Garf last edited by

          Du musst die gewünschten Daten aus dem String herausschneiden (parsen).

          Schau dir dies mal an:

          https://stackoverflow.com/questions/449 … sg-payload

          https://www.w3schools.com/Jsref/jsref_substring.asp

          https://developer.mozilla.org/de/docs/W ... /substring

          https://de.wikibooks.org/wiki/Websiteen ... te:_String

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

            Habe das mal so versucht in eine funktion gepackt

            var msg = msg.payload;
            var value = msg.substr(99,103);
            return msg;
            
            

            klappt leider nicht bin wohl noch ziemlicher Anfänger :?

            Verstehe zwar was ich machen muß krieg das aber in nod-red

            nicht hin.

            1 Reply Last reply Reply Quote 0
            • G
              Garf last edited by

              Nein, so kann es nicht funktionieren.

              Du musst die Variable value wieder der Variable msg.payload zuweisen. Dann kannst Du auch das Ergebnis im Debug-Node sehen.

              var msg = msg.payload;
              var value = msg.substr(99,103);
              msg.payload = value;
              return msg;
              

              Der Weg wird aber kein zufriedenstellendes Ergebnis bringen, da sich die Werte und damit die Länge des Strings verändern können. Du schneidest aber an genau definierten Stellen einen Teilstring aus.

              Ich würde den gesamten String in Einzelwerte zerlegen und in ein Array schreiben. Sähe dann so aus:

              3639_screen1.jpg

              Deine gewünschten Werte stehen in der Variablen msg.paylaod[5] und msg.paylaod[8].

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

                Danke für deine Hilfe 🙂

                ok ich lege eine Funktion an

                msg.payload :array[9]

                und extrahiere dann daraus mit

                msg.paylaod[5] und msg.paylaod[8]

                meine gewünschten Variablen.

                Wie würde der Code aussehen um das ganze in ein Array zu schreiben ?

                1 Reply Last reply Reply Quote 0
                • G
                  Garf last edited by

                  Klar könnte ich dir das fertige Javascript posten und Du hättest die Lösung. Besser wäre es jedoch, wenn Du verstehst was Du da eigentlich machst und wie dies alles in Node Red so funktioniert.

                  Aus deinem Posts kann ich herauslesen, dass bei dir das Grundlagenwissen und Verständnis noch fehlt. :roll:

                  Ist auch nachvollziehbar und nicht schlimm. Woher soll man es als Anfänger auch haben.

                  Hier kannst Du dich in das Thema einlesen: https://nodered.org/docs/user-guide/messages

                  Mich würde erst einmal interessieren, ob Du dein vorheriges Script um die eine Zeile ergänzt hast und nun ein Ergebnis im debug Node siehst. Wenn ja, wie sieht dies aus?

                  Deshalb bleibe noch kurz bei deinem kleinen Javascript und schau dir das Ergebnis mit dem Substring genau an. Im Anschluss machen wir uns dann auf den richtigen Weg und benutzen an Stelle der Substring Javafunktion die Splitfunktion. Diese erstellt automatisch die Array. Ich schaue mich in der Zwischenzeit noch mal um, ob es hierfür nicht schon ein fertiges Node gibt.

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

                    Hallo

                    Wenn ich diese Funktion einfüge bekomme ich im Debug dies

                    "Function tried to send a message of type string"

                    var msg = msg.payload;

                    var test = msg.substr(3,6);

                    msg.payload = test;

                    return msg;

                    egal welche zahlen ich eingebe bekomme nur diese Fehlermeldung

                    Ines

                    1 Reply Last reply Reply Quote 0
                    • G
                      Garf last edited by

                      Hi,

                      eine unglückliche Auswahl der Variablennamen führt zu dem Fehler.

                      Versuche es bitte mit folgendem Javascript:

                      var string = msg.payload;
                      var test = string.substr(3,6);
                      msg.payload = test;
                      return msg;
                      

                      Hier noch der kleine Testflow.

                      [{"id":"a34c31f5.640b28","type":"inject","z":"1109363a.41365a","name":"","topic":"","payload":"{\"Time\":\"2018-06-08T15:22:49\",\"ENERGY\":{\"Total\":66.302,\"Yesterday\":0.410,\"Today\":0.268,\"Period\":1,\"Power\":18,\"Factor\":0.48,\"Voltage\":231,\"Current\":0.162}}","payloadType":"str","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":110,"y":200,"wires":[["8c0169c.096a698"]]},{"id":"8c0169c.096a698","type":"function","z":"1109363a.41365a","name":"","func":"var string = msg.payload;\nvar test = string.substr(3,6);\nmsg.payload = test;\nreturn msg;","outputs":1,"noerr":0,"x":330,"y":200,"wires":[["147c1657.ec1dc2"]]},{"id":"147c1657.ec1dc2","type":"debug","z":"1109363a.41365a","name":"","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","x":520,"y":200,"wires":[]}]
                      

                      Dann bitte ein wenig testen und wieder melden. Dann gehen wir das eigentliche Problem an, damit du endlich zu dem gewünschten Ergebnis kommst.

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

                        Wenn ich diesen Code verwende bekomme ich als Anzeige im gauge

                        var string = msg.payload;
                        var test = string.substr(9,10);
                        msg.payload = test;
                        return msg;
                        

                        "2018" warum versteh ich noch nicht so richtig wie wird das im String gezählt ?

                        Mit inject node string und debug node bekomme ich von deinen testflow dies

                        "id":"a" als filter habe ich das verwendet

                         var string = msg.payload;
                        var test = string.substr(3,6);
                        msg.payload = test;
                        return msg;
                        

                        Bei a34c31f und diesen code

                        var string = msg.payload;
                        var test = string.substr(7,8);
                        msg.payload = test;
                        return msg;
                        

                        Verstehe einfach nicht wie das gezählt hier wird

                        Ines

                        1 Reply Last reply Reply Quote 0
                        • G
                          Garf last edited by

                          @inesa:

                          Wenn ich diesen Code verwende bekomme ich als Anzeige im gauge "2018" warum versteh ich noch nicht so richtig wie wird das im String gezählt ? `

                          Das kann doch nicht funktionieren. Das Dashboard gauge Node erwartet einen Zahlenwert (float oder integer) und keinen String. Wir benutzen zur Zeit nur Strings. Warum bleibst Du nicht erst auf der Flowseite und schaust dir die Ergebnisse im debug Node an?

                          Die Ergebenisse sieht man rechts unter debug.

                          3639_screen2.jpg

                          > Wie kann man deinen teststring einsetzen… Mit den Grundlagen solltest Du dich aber noch einmal sehr intensiv beschäftigen!

                          Das ist ein Flow (clipboard), den importiert man nach Node Red. Über das Menü, dann import auswählen, dann Clipboard und mit copy und paste den Code in das große Fenster kopieren und auf deiner Flowseite abspeichern. Die Links zu den Youtube Videos zeigen wie es geht.

                          https://www.youtube.com/watch?v=_uN–N7YE24

                          https://www.youtube.com/watch?v=vLhVxWRtWc8

                          1 Reply Last reply Reply Quote 0
                          • Homoran
                            Homoran Global Moderator Administrators last edited by

                            @Garf:

                            Mit den Grundlagen solltest Du dich aber noch einmal sehr intensiv beschäftigen! `

                            Hier gibt es auch noch etwas:

                            http://www.iobroker.net/docu/?page_id=4284&lang=de

                            Gruß

                            Rainer

                            1 Reply Last reply Reply Quote 0
                            • G
                              Garf last edited by

                              @Homoran:

                              Hier gibt es auch noch etwas: `
                              Super, vielen Dank, das kannte ich auch noch nicht.

                              Vielleicht sollt man diese und andere allgemeine Infos zu Node Red unter Bekanntmachungen anpinnen. Die Gesamtübersicht aller Anleitung finde ich etwas unübersichtlich.

                              1 Reply Last reply Reply Quote 0
                              • Homoran
                                Homoran Global Moderator Administrators last edited by

                                Wir werden die Doku (hoffentlich) bald überarbeiten. Die ist nicht immer auf dem aktuellen Stand.

                                So ist diese Seite von Mai 2016 😞

                                Merkwürdigerweise funktioniert die Suche darin aber sehr gut 😄

                                Gruß

                                Rainer

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

                                  Das mit dem Testflow hab ich schon mal hinbekommen

                                  Der Rest muss auf heute Abend warten.

                                  Dank an euch schon mal

                                  Ines

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

                                    Mit diesen Code habe ich meine gewünschte Ausgabe hinbekommen

                                    var string = msg.payload;
                                    var test = string.substr(106,2);
                                    msg.payload = test;
                                    return msg;
                                    

                                    Einen flow zur Ausgabe auf meinen Dashboard mit livedaten vom Sonoff Pow

                                    habe ich mir auch gleich zusammengebaut.Nur leider ändert sich der String manchmal

                                    und die Ausgabe ist dann fehlerhaft.Zufriednstellend ist das leider noch nicht.

                                    Im debug Fenster wird mir nach import des flows nicht das Array angezeigt wie man es

                                    bei Graf sehen kann.

                                    Warum ist das so ?

                                    Ines

                                    1 Reply Last reply Reply Quote 0
                                    • G
                                      Garf last edited by

                                      @inesa:

                                      Warum ist das so ? Weil Du noch viel in Javascriptprogrammierung und der Verwendung unter Node Red lernen musst. Da mir primär die Zeit und auch wenig die Lust fehlt, dir dies aus der Ferne Schritt für Schritt beizubringen, setze ich auf diese Aussage von dir > Das mit dem Testflow hab ich schon mal hinbekommen `
                                      und poste die fertige Lösung. In den vorherigen Posts hatte ich übrigens bereits geschrieben, dass die substring Methode nicht der richtige Weg zum gewünschten Ergebnis ist, da mit der substring Funktion an genau vorher definierten Stellen etwas abgeschnitten wird, sich aber die Positionen der Messwerte je nach Messgröße verändern können. Somit ein absolutes no go.

                                      [{"id":"a34c31f5.640b28","type":"inject","z":"1109363a.41365a","name":"","topic":"","payload":"{\"Time\":\"2018-06-08T15:22:49\",\"ENERGY\":{\"Total\":66.302,\"Yesterday\":0.410,\"Today\":0.268,\"Period\":1,\"Power\":18,\"Factor\":0.48,\"Voltage\":231,\"Current\":0.162}}","payloadType":"str","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":150,"y":100,"wires":[["8a3b7ff7.cec02"]]},{"id":"8a3b7ff7.cec02","type":"function","z":"1109363a.41365a","name":"","func":"var oldstring = msg.payload;\nvar newstring = oldstring.replace(/{|}|\"/g,\"\");\nvar re = /\\s*,\\s*/;\nvar nameList = newstring.split(re);\nmsg.payload=nameList;\nflow.set(\"power\",msg.payload[5]);\nflow.set(\"current\",msg.payload[8]);\nreturn msg;","outputs":1,"noerr":0,"x":350,"y":100,"wires":[["df30b04d.fcd7b8","741a4d3f.db3874","9d5094c1.7897a8"]]},{"id":"df30b04d.fcd7b8","type":"debug","z":"1109363a.41365a","name":"","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"false","x":530,"y":100,"wires":[]},{"id":"741a4d3f.db3874","type":"function","z":"1109363a.41365a","name":"Power","func":"var oldstring = flow.get(\"power\");\nvar newstring = oldstring.replace(/Power:/g,\"\");\nmsg.payload =parseFloat(newstring);\nreturn msg;","outputs":1,"noerr":0,"x":360,"y":160,"wires":[["a94fb3d7.b87a9","9d7b9caf.b00dc"]]},{"id":"9d5094c1.7897a8","type":"function","z":"1109363a.41365a","name":"current","func":"var oldstring = flow.get(\"current\");\nvar newstring = oldstring.replace(/Current:/g,\"\");\nmsg.payload =parseFloat(newstring);\nreturn msg;","outputs":1,"noerr":0,"x":369,"y":200,"wires":[["362d4eb.a67d3b2","19d2e720.226ca9"]]}]
                                      

                                      Und so sollte es dann nachher aussehen:

                                      3639_screen4.jpg
                                      Beispieltestflow

                                      3639_screen5.jpg
                                      Anzeigewerte Debug-Nodes

                                      3639_screen6.jpg
                                      Gauge-Anzeigen im Dashboard

                                      Jetzt schau mal, dass Du die drei function-Nodes in dein Flow eingebaut bekommst. Und bitte nicht frustiert sein. Das was Du hier machen möchtest ist vom Schwierigkeitsgrad her etwas für Fortgeschrittenen.

                                      Wenn Du noch Fragen hast, oder noch etwas fehlt bzw. nicht funktioniert dann kannst Du dich gerne wieder melden.

                                      Über ein Feedback, gerne auch mit Screenshots, freue ich mich immer sehr. Getreu dem Motto von John „Hannibal“ Smith: > ****Ich liebe es, wenn ein Plan funktioniert.****

                                      Und jetzt viel Erfolg damit.

                                      Gruß

                                      Garf

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

                                        Danke Graf für deine Hilfe werde versuchen das in meinen flow mit einzubauen.

                                        Wie ich das von Dir verstanden habe würde das auch mit anderen flow's funktionieren ?

                                        Ich möchte bei mir zu Hause sämtliche Geräte in nod-red einbauen um es dann

                                        übersichtlich auf einen Tablet darzustellen. Ein schalten von Licht oder anderen Dingen

                                        war bisher nicht das Problem was ja auch recht simpel ist im Dashboard abzubilden.

                                        Die visuelle Darstellung von Messwerten bereit mir noch Schwierigkeiten.

                                        Eine simple Darstellung des aktuellen Wetters mit Openweather was mein erster Versuch

                                        der sich gut mit etwas code realisieren ließ

                                        return { payload: msg.payload.tempc};
                                        

                                        Ok jetzt mach ich mich an Arbeit nochmals vielen Dank

                                        Ines

                                        1 Reply Last reply Reply Quote 0
                                        • G
                                          Garf last edited by

                                          @inesa:

                                          Ok jetzt mach ich mich an Arbeit nochmals vielen Dank `

                                          Und wie läuft es?

                                          Heute noch eine deutlich einfachere Lösung gefunden.

                                          3639_screen11.jpg

                                          3639_screen12.jpg

                                          Und hier noch der Flow

                                          [{"id":"8c0169c.096a698","type":"function","z":"1109363a.41365a","name":"Power","func":"var myObj, x;\nmyObj = msg.payload;\nx = myObj.ENERGY.Power;\nmsg.payload = x;\nreturn msg;","outputs":1,"noerr":0,"x":350,"y":24,"wires":[["147c1657.ec1dc2"]]},{"id":"147c1657.ec1dc2","type":"debug","z":"1109363a.41365a","name":"Power","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","x":540,"y":24,"wires":[]},{"id":"d6bdcf92.0373f","type":"inject","z":"1109363a.41365a","name":"","topic":"","payload":"{\"Time\":\"2018-06-08T15:22:49\",\"ENERGY\":{\"Total\":66.302,\"Yesterday\":0.41,\"Today\":0.268,\"Period\":1,\"Power\":18,\"Factor\":0.48,\"Voltage\":231,\"Current\":0.162}}","payloadType":"json","repeat":"","crontab":"","once":false,"onceDelay":0.1,"x":150,"y":24,"wires":[["8c0169c.096a698","cdcf5d25.55b6a8"]]},{"id":"cdcf5d25.55b6a8","type":"function","z":"1109363a.41365a","name":"current","func":"var myObj, x;\nmyObj = msg.payload;\nx = myObj.ENERGY.Current;\nmsg.payload = x;\nreturn msg;","outputs":1,"noerr":0,"x":360,"y":60,"wires":[["cfa3e142.36cc68"]]},{"id":"cfa3e142.36cc68","type":"debug","z":"1109363a.41365a","name":"Strom","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"payload","x":539,"y":60,"wires":[]}]
                                          

                                          Und genau diese Lösung hatte Je Cee bereits am 08.06. gepostet. Ist mir jetzt ein wenig peinlich, positiv betrachtet habe ich aber auch wieder eine Menge dazu gelernt. 😉

                                          @Jey Cee:

                                          msg.payload=msg.payload.ENERGY.Power;
                                          

                                          Damit müsste es gehen. `
                                          Ja, funktioniert einwandfrei.

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

                                            Deinen ersten Vorschlag habe ich gut hinbekommen.

                                            Hab jetzt auch schon mehrere Sache wie Temperaturfühler Wetterstation und diverse

                                            Schalter einbinden können.

                                            🙂

                                            Bin noch fleißig am testen

                                            Die Oberfläche in nod-red sagt mir noch nicht zu weil die Räume

                                            hier untereinander angeordnet sind aber das läßt sich

                                            bestimmt noch irdendwie ändern

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            811
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            4
                                            24
                                            20560
                                            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