Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Node-Red
    5. Ausgabe Node-Red an Datenpunkt

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Ausgabe Node-Red an Datenpunkt

    This topic has been deleted. Only users with topic management privileges can see it.
    • T
      Toby 2 last edited by

      Hallo,

      über Node-Red frage ich eine MySql Datenbank ab.
      Das Ergebnis ist im Beispiel der Wert "1878".
      Auf dem Datenpunkt im ioBroker kommt jedoch der gesamte Text mit an also "Sum(ack): 1878"

      Wie kann ich den Text entfernen so dass nu noch der Nummerische Wert übergeben wird?node-red.png

      mickym 2 Replies Last reply Reply Quote 0
      • mickym
        mickym Most Active @Toby 2 last edited by mickym

        @toby-2 Indem Du aus dem Array von Objekten den Wert extrahierst. Am Besten ist immer Du gehst mit der Maus neben den Wert und kopierst den Pfad raus.

        copy path.gif

        Ich zeige es Dir an Deinem Beispiel. In Deinem Fall ist es ein klein wenig komplizierter, weil der Pfad in JS notation kommt, deswegen den Pfad wie folgt modifizieren.

        d89630b2-000c-422c-83d0-dce1917d9f7f-image.png

        Hier die Change-Node um den Wert zu extrahieren als Import:

        [
            {
                "id": "13349338e08d91ed",
                "type": "change",
                "z": "7e6af0015415146d",
                "name": "",
                "rules": [
                    {
                        "t": "set",
                        "p": "payload",
                        "pt": "msg",
                        "to": "payload.0[\"Sum (ack)\"]",
                        "tot": "msg"
                    }
                ],
                "action": "",
                "property": "",
                "from": "",
                "to": "",
                "reg": false,
                "x": 470,
                "y": 4240,
                "wires": [
                    [
                        "485afa41b273e7e6"
                    ]
                ]
            }
        ]
        

        Wie gesagt in Deinem Fall muss man leider an den Pfad Hand anlegen.

        Aus dem kopierten Pfad:

        payload[0]["Sum (ack)"]
        

        musst Du erst die Punkt-Notation nutzen.

        payload.0["Sum (ack)"]
        
        T 1 Reply Last reply Reply Quote 0
        • mickym
          mickym Most Active @Toby 2 last edited by

          @toby-2 Alternativ empfehle ich Dir aber in diesem Fall ein Array - also wenn ein Schwung von Werten kommt die erst in einzelne Nachrichten aufzudröseln.

          48bddaf5-7431-4858-b4ed-4521f847cd88-image.png

          Die spit Node macht also zum Beispiel aus dem Array einzelne Nachrichten wenn Du nun den Pfad kopierst dann kannst Du ihn direkt verwenden.

          payload["Sum (ack)"]
          

          Später kannst Du Dich auch mit JSONATA beschäftigen - eine sehr mächtige Bibliothek, die in NodeRed eingebaut ist und die Dir im ersten Schritt auch ein Array mit den extrahierten Werten aus dem Objekt liefert.

          1 Reply Last reply Reply Quote 0
          • T
            Toby 2 @mickym last edited by

            @mickym
            Super mickym, Vielen Dank!
            Das funktioniert klasse mit deinem ersten Vorschlag. Ich taste mich da mal weiter voran

            Homoran 1 Reply Last reply Reply Quote 0
            • mickym
              mickym Most Active last edited by mickym

              Wenn Du über die SQL-Abfrage nur 1 Feld abfragst, dann ist der Feldname eigentlich unwichtig und Deine Objekte bestehen nur aus einer Eigenschaft - dann ist der Name dieser Eigenschaft auch egal. Dann kannst Du auch direkt JSONATA verwenden. Diese Form ist also universell einsetzbar - solange Du nur 1 Feld abfragst!

              1b4aaa74-7c40-4f59-bf75-4d4e8d52d7ef-image.png

              Du siehst auch das funktioniert.

              mickym 1 Reply Last reply Reply Quote 0
              • Homoran
                Homoran Global Moderator Administrators @Toby 2 last edited by

                @toby-2 sagte in Ausgabe Node-Red an Datenpunkt:

                Super micky

                Screenshot_20231015-131604_Firefox.jpg

                mickym 1 Reply Last reply Reply Quote 0
                • mickym
                  mickym Most Active @mickym last edited by mickym

                  @mickym Und noch ein TIPP - vermeide function Nodes so gut es geht - auch wenn Du da oft Beispiele setzt.

                  In Deiner function Node wird nur so was drinstehen:

                  msg.topic = "SELECT ...."

                  setzte das topic einfach über eine Change Node:

                  4e07ffa3-6f14-4cc5-9582-896c04c764fe-image.png

                  gewöhne Dir den anderen Mist gar nicht an.

                  Auch wenn Du selbst mit einer Inject Node triggern willst. Auch dort kannst Du direkt Deine select Abfrage ins topic schreiben:

                  2bd53fe7-e80f-400f-9d43-be405c0bd3f8-image.png

                  Du siehst eine SQL Abfrage einfach in das topic der Nachrichteigenschaft rein schreiben, das geht auch mit einer Inject Node.

                  Später wirst Du Dir für komplexere Abfragen aus verschiedenen Nachrichteneigenschaften Deine SQL Abfrage ggf. basteln:

                  5f4b5799-93d5-42e8-9561-a87f94973413-image.png

                  in diese Template Node (SQL get events) kannst Du dann Deine SQL Abfrage formulieren und variabel mit Deinen Nachrichteneigenschaften verändern.

                  8de28a1b-f3de-4c6d-8315-cb095c0a99b2-image.png

                  1 Reply Last reply Reply Quote 0
                  • mickym
                    mickym Most Active @Homoran last edited by

                    @homoran 🤣 🤣 🤣

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

                    Support us

                    ioBroker
                    Community Adapters
                    Donate

                    1.1k
                    Online

                    31.7k
                    Users

                    79.7k
                    Topics

                    1.3m
                    Posts

                    3
                    8
                    461
                    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