Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Node-Red: Node zum Abfragen eines ioBroker State im Flow

    NEWS

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    Node-Red: Node zum Abfragen eines ioBroker State im Flow

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

      Hi!

      Und danke! Ich werde es heute abend mal testen, ob ich damit klar komme.

      Aber wenn ich es richtig interpretiere hast du das gemacht wobei ich schon seit Wochen mir die Zähne ausbeiße…

      Werde Feedback geben....

      Grüße

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

        Nochmal ich,

        also zum Austauschen mit deiner Anleitung ist es Idiotensicher!

        Hab sogar ich hinbekmmen 🙂

        Ich denke das wäre wirklich etwas zum Standart mäßigen einbinden.

        Wie es sich in der Praxis verhält muss ich jetzt erst mal ausprobieren.

        Kleines Problem habe ich aber jetzt schon….

        siehe Bild

        irgendwas ist da passiert bzw passt noch nicht ganz...

        703_unbenannt.jpg

        aber jetzt probiere ich es erst mal aus….

        FETTES DANKE schonmal.

        Tobi

        1 Reply Last reply Reply Quote 0
        • N
          nobody last edited by

          Hallo Tobi,

          danke für die Rückmeldung.

          Scheint ein Bug in älteren node-red Versionen zu sein, dass man in der html-Datei das Icon alignment nur auf right, nicht aber explzit auf left setzen darf. Mit 0.12.4 und 0.12.5 war die Anzeige korrekt.

          Ich hab im ersten Post die ZIP-Datei ausgetauscht. Kannst du die nochmal testen?

          Klappt bei dir die Abfrage der Daten korrekt?

          Ich hab in der neuen Version der iobroker.js auch maxListeners auf 100 gesetzt, weil mich die Warnmeldungen im Log bei jedem Start genervt hat, wenn man mehr als 11 iobroker Nodes verwendet hat.

          Gruß

          Markus

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

            HI,

            danke für die schnelle Arbeit!

            Funktioniert… also Text wird richtig angezeigt.

            gruß Tobi

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

              Neue iobroker.node-red Version ist draußen.

              Danke "nobody" :!:

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

                Super - dann brauche ich am Wochenende nicht "basteln", sondern kann das Update ziehen.

                Danke!

                Gruß,

                Eric

                1 Reply Last reply Reply Quote 0
                • N
                  nobody last edited by

                  Hallo apollon77,

                  schön, dass auch das Team von node-red weiterentwickelt.

                  Wenn man sich unter https://github.com/node-red/node-red/bl … -switch.js die Änderungen anschaut, macht der neue switch node aber auch nichts anderes, als den letzten Wert im Node Objekt zwischen zu speichern. Somit kann er erstmal auch nicht mehr als der rbe node jetzt schon. Eigentlich sogar weniger, weil sich der Node immer den Wert der letzten msg speichert und nicht nur die, die tatsächlich weiter geleitet wurden. Somit taugt das schon nicht mehr für Abweichungen, da schleichende Änderungen dann zu keiner Weiterleitung führen.

                  Gesendet von meinem GT-N8000 mit Tapatalk
                  9656_20181220_1.jpg
                  9656_20181220_2.jpg

                  1 Reply Last reply Reply Quote 0
                  • N
                    nobody last edited by

                    Solche Prüfungen direkt in den iobroker in node einzubauen sollte eigentlich auch kein großes Problem sein.

                    Aus meiner Sicht sinnvoll wären die folgenden Optionen:

                    Auslösen nur bei bestätigten Werten (ack==true)

                    Auslösen nur bei Wert Änderungen zum letzten weitergeleiteten Wert.

                    Auslösen nur bei einer Mindeständerung zum letzten weitergeleiteten Wert analog rbe.

                    Optional Konvertierung von string nach boolean, int, float, datetime zur einfachen Weiterverarbeitung.

                    Ich kann die Erweiterung vornehmen, hab aber noch keine Ahnung, wann ich dazu komme.

                    Gesendet von meinem GT-N8000 mit Tapatalk

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

                      Hi,

                      wenn man das direkt einbauen kann cool 🙂 Da ich es nicht selbst kann warte ich gern bis es bei Dir passt.

                      Mir geht es (ok, neben dem ausprobieren ob man node-red so nutzen könnte das ich von ccu.io mit ScriptGUI zu iobroker mit node-red wechseln kann) auch darum für iobroker ein Featureset zu haben was denke auch anderen Nutzern hilft.

                      So wie ich es verstehe kann Switch dann schon ein bissl mehr als RBE, weil RBE aktuell nur "!=" kann … Switch kann von Hause aus ja auch die anderen Vergleichsoperatoren ...

                      1 Reply Last reply Reply Quote 0
                      • N
                        nobody last edited by

                        Hi appollon77,

                        der rbe Node kann auch jetzt schon auf absolute und relative Abweichungen zum Vorwert prüfen. Nennt sich Deadband mode und kann über die Node-Eigenschaften konfiguriert werden.

                        In der aktuellen node-red-Version 0.12.5 ist das schon drin.

                        Der node-red-Adapter erzwingt zurzeit nicht die Version 0.12.5. Im zweifel muss man die manuell upgraden.

                        Deadband mode

                        In deadband mode the incoming payload should contain a parseable number and is output only if greater than + or - the band gap away from the previous output.

                        The deadband value can be specified as a fixed number, or a percentage. E.g. 10 or 5% . If % mode is used then the output will only get sent if the input payload value is equal or more than the specified % away from the previously sent value.

                        For example - if last sent value was 100, and deadband is set to 10% - a value of 110 will pass - then the next value has to be 121 in order to pass (= 110 + 10% = 121).

                        This is mainly useful if you want to operate across multiple topics at the same time that may have widely differing input ranges.

                        Will only accept numbers, or parseable strings like "18.4 C" or "$500"

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

                          Hi nobody,

                          ich hab die 0.12.5.

                          Das die RBE Node das kann hatte ich gesehen. Ist in meinen Augen aber halt was anderes als die Logiken die ich als nötig ansehe 🙂

                          1 Reply Last reply Reply Quote 0
                          • N
                            nobody last edited by

                            Hi,

                            eine erweitere Version des node-red Adapters ist nun als pull Request auf github.

                            Man kann jetzt im in-Node auf acknowledge==true filtern und hat zusätzlich wie im rbe node die Möglichkeit auf Wertveränderung oder Mindestabweichung zu filtern.

                            Die Konvertierung des Datentyps ist nach nochmaliger Überlegung doch nicht so sinnvoll, weil insbesondere Boolean im Attribut payload sowieso wieder in String konvertiert wird.

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

                              Hi nobody, echt cool! Danke!

                              Denkst Du das weitere "Vergleichsoperatoren" noch sinn machen?

                              Was jetzt da ist ist "!=" (ala RBE) und "Abweichung mindestens X". Oder ist der Rest dann sinnvoll über die neuen "Switch"-Funktionen?

                              Ich denke das mindestens "==" noch Sinn macht auch wenn es RBE nicht hat 🙂

                              1 Reply Last reply Reply Quote 0
                              • N
                                nobody last edited by

                                Gleichheit zum Vorwert oder zu einem konfigurierten festen Wert? Letzteres würde schon sinnvoll sein.

                                Gesendet von meinem SM-G900F mit Tapatalk

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

                                  Gleichheit zu festem Wert ist einfach per Switch machbar … von daher wäre es cool weil es ein Node spart, aber ob es Sinn macht weiss ich nicht.

                                  Und ja ich habe gerade nochmal alle meine CCU.io Skripte durchgesucht und in nehme wirklich nur "bei Aktualisierung" und "bei Änderung" (!=) ... von daher passt so 🙂

                                  Update: Jain ... Am Ende wäre es manchmal Sinnvoll den Vorherigen Wert in der Message zu haben. Beispiel: Ich habe eine Anwesenheitserkennung gebaut nach einem Konzept was mal im HM-Forum beschrieben wurde. Das arbeitet mit einem Zähler und es sind auch Notifies drin zu Anwesenheit und Abwesenheit.

                                  Ich habe hier die Logik drin das beim Wert 30 wenn der alte Wert <30 war (also der Wert wird gerade größer) ist es "Anwesenheit"... Wie kann ich das machen mit node-red? Da bräuchte man entweder Zugriff auf den "alten Wert" (per GetIoBrokerNode oder so?) oder ?!

                                  1 Reply Last reply Reply Quote 0
                                  • N
                                    nobody last edited by

                                    Die Anforderung ist aus meiner Sicht schon so speziell, dass ich diese nicht mehr in einem in-Node sondern in einem function-Node sehe. Der Vergleich auf alterWert<30 setzt das Wissen über den alten Wert voraus, der aber nicht gesendet wurde. Für deathband wird aber genau der zuletzt weitergeleitete alte Wert benötigt.

                                    Den zuletzt weitergegebenen Wert raus zu geben wäre technisch zwar möglich, würde aber ein wenig dem Konzept für in-Nodes widersprechen.

                                    Die Logik im function-Node zu realisieren sind aber auch nur ein paar Zeilen JavaScript. Den alten Wert kann man ja einfach in context.global.[nameAlterWert] ablegen.

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

                                      Alles klar, dann versuche ich das mal so 🙂

                                      Danke!

                                      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

                                      852
                                      Online

                                      31.6k
                                      Users

                                      79.4k
                                      Topics

                                      1.3m
                                      Posts

                                      5
                                      19
                                      7320
                                      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