Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Node-Red
  5. Hilfe bei debuggen einer übernommenen Funktion

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.8k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.3k

Hilfe bei debuggen einer übernommenen Funktion

Geplant Angeheftet Gesperrt Verschoben Node-Red
157 Beiträge 2 Kommentatoren 15.1k Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • mickymM mickym

    @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

    @mickym

    Aus meiner Sicht reicht, wenn die FIlterpumpe zeitgesteuert läuft, da die ja in Abhängigkeit des Betriebs der Dosierpumpen steht.

    Na durch das Filter über das Zeitfenster läuft sie ja zeitgesteuert. Ich würde vorschlagen. Du implementierst diese function Node, Schritt für Schritt in einen Flow. Damit verstehst Du das Ganze und kannst es dann selbst modifizieren? - OK? - dann mach Dir jetzt mal keinen Gedanken über die Logik, sondern übersetze das mal in einen Flow.

    Die erste Anweisung ist also das hier:

    msg.payload.ph = Number((msg.payload.ph_current + 0.2).toFixed(2));
    

    Was macht die denn? - Ich meine nicht was sie programmtechnisch macht (sehe ich ja selbst), sondern was Du glaubst, was sie macht.

    B Offline
    B Offline
    BF0911
    schrieb am zuletzt editiert von
    #14

    @mickym

    Ok, das klingt nach einem sehr guten Plan.

    Ich würde sagen, dass diese Funktion (toFixed(2)) auf 2 Dezimalzahlen nach dem Komma kürzt. Das erste dürfe eine normale Addition sein?

    mickymM 1 Antwort Letzte Antwort
    0
    • B BF0911

      @mickym

      Ok, das klingt nach einem sehr guten Plan.

      Ich würde sagen, dass diese Funktion (toFixed(2)) auf 2 Dezimalzahlen nach dem Komma kürzt. Das erste dürfe eine normale Addition sein?

      mickymM Online
      mickymM Online
      mickym
      Most Active
      schrieb am zuletzt editiert von
      #15

      @bf0911 Ja und zwar wird die Eigenschaft Deiner payload verwendet und in eine Zahl verwandelt, wobei das in meinen Augen überflüssig ist, sonst könnte er das ja nicht 0.2 zu der Eigenschaft ph_current dazu zählen.

      Wir modifizieren also mittels einer Change Node das gleiche und fangen den Flow nun an.
      Mit JSONATA kannst Du solche Operationen direkt machen

      e940894f-079d-46fd-8011-36a90987d41b-image.png

      Deine Change Node wird also so aussehen:

      163fbbf8-c542-4c7c-8664-b3cbc3b4ada5-image.png

      5e24c323-0f5b-4bc5-b0fe-907429beeaaa-image.png

      Also du setzt die Eigenschaft ph in Deiner payload.

      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

      B 1 Antwort Letzte Antwort
      0
      • mickymM mickym

        @bf0911 Ja und zwar wird die Eigenschaft Deiner payload verwendet und in eine Zahl verwandelt, wobei das in meinen Augen überflüssig ist, sonst könnte er das ja nicht 0.2 zu der Eigenschaft ph_current dazu zählen.

        Wir modifizieren also mittels einer Change Node das gleiche und fangen den Flow nun an.
        Mit JSONATA kannst Du solche Operationen direkt machen

        e940894f-079d-46fd-8011-36a90987d41b-image.png

        Deine Change Node wird also so aussehen:

        163fbbf8-c542-4c7c-8664-b3cbc3b4ada5-image.png

        5e24c323-0f5b-4bc5-b0fe-907429beeaaa-image.png

        Also du setzt die Eigenschaft ph in Deiner payload.

        B Offline
        B Offline
        BF0911
        schrieb am zuletzt editiert von
        #16

        @mickym

        Das bedeutet, als Beispiel er addiert zu dem WErt 7,4 0,2 was 7,6 ergeben würde?

        WEnn dem so wäre, würde das auch kein Sinn machen, weil der gemessene PH-Wert ja die Schwelle sein soll

        mickymM 2 Antworten Letzte Antwort
        0
        • B BF0911

          @mickym

          Das bedeutet, als Beispiel er addiert zu dem WErt 7,4 0,2 was 7,6 ergeben würde?

          WEnn dem so wäre, würde das auch kein Sinn machen, weil der gemessene PH-Wert ja die Schwelle sein soll

          mickymM Online
          mickymM Online
          mickym
          Most Active
          schrieb am zuletzt editiert von mickym
          #17

          @bf0911 Na ja das kannst Du ja später ändern, aber im Moment würde in Deinem Nachrichtenobjekt die Eigenschaft ph um 0.2 größer als ph_current sein. Warum auch immer. :grin:

          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

          B 1 Antwort Letzte Antwort
          0
          • B BF0911

            @mickym

            Das bedeutet, als Beispiel er addiert zu dem WErt 7,4 0,2 was 7,6 ergeben würde?

            WEnn dem so wäre, würde das auch kein Sinn machen, weil der gemessene PH-Wert ja die Schwelle sein soll

            mickymM Online
            mickymM Online
            mickym
            Most Active
            schrieb am zuletzt editiert von mickym
            #18

            @bf0911 Was Du mal machen kannst ist - an Deine Node VOR der function Node eine Debug Node machen und dir das GANZE Nachrichtenobjekt dirausgeben lassen und hier in CodeTags einstellen, damit DU siehst, was für Eigenschaft Dein Nachrichtenobjekt hat.

            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

            mickymM 1 Antwort Letzte Antwort
            0
            • mickymM mickym

              @bf0911 Na ja das kannst Du ja später ändern, aber im Moment würde in Deinem Nachrichtenobjekt die Eigenschaft ph um 0.2 größer als ph_current sein. Warum auch immer. :grin:

              B Offline
              B Offline
              BF0911
              schrieb am zuletzt editiert von
              #19

              @mickym

              Ok, dann folge ich erstmal nur deinen "Anweisungen".

              DAnke schon.

              Ich entschuldige aber direkt, wenn es mal ein paar Stunden etc. keine Antwort gibt.

              mickymM 1 Antwort Letzte Antwort
              0
              • B BF0911

                @mickym

                Ok, dann folge ich erstmal nur deinen "Anweisungen".

                DAnke schon.

                Ich entschuldige aber direkt, wenn es mal ein paar Stunden etc. keine Antwort gibt.

                mickymM Online
                mickymM Online
                mickym
                Most Active
                schrieb am zuletzt editiert von
                #20

                @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                @mickym

                Ok, dann folge ich erstmal nur deinen "Anweisungen".

                DAnke schon.

                Ich entschuldige aber direkt, wenn es mal ein paar Stunden etc. keine Antwort gibt.

                Dann sag vorher Bescheid, ich sitze auch nicht immer am Rechner.

                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                1 Antwort Letzte Antwort
                0
                • mickymM mickym

                  @bf0911 Was Du mal machen kannst ist - an Deine Node VOR der function Node eine Debug Node machen und dir das GANZE Nachrichtenobjekt dirausgeben lassen und hier in CodeTags einstellen, damit DU siehst, was für Eigenschaft Dein Nachrichtenobjekt hat.

                  mickymM Online
                  mickymM Online
                  mickym
                  Most Active
                  schrieb am zuletzt editiert von mickym
                  #21

                  @mickym sagte in Hilfe bei debuggen einer übernommenen Funktion:

                  @bf0911 Was Du mal machen kannst ist - an Deine Node VOR der function Node eine Debug Node machen und dir das GANZE Nachrichtenobjekt dirausgeben lassen und hier in CodeTags einstellen, damit DU siehst, was für Eigenschaft Dein Nachrichtenobjekt hat.

                  Um ein Nachrichtenobjekt vollständig auszugeben, hängst Du wie gesagt eine Debug Node an die vorherige Node und gibst das vollständige Nachrichtenobjekt aus:

                  Das debug Tab ist das mit dem Käfer (Bug).

                  8ee4d433-3ca1-4c9a-b53c-29ed627fbcd1-image.png

                  Der Vorteil an einem Flow ist nun - dass nach jedem Schritt / node - also auch nach der Change Node, die wir erstellt haben, eine Debug Node anhängen können und bei Bedarf sehen können, wenn sich was verändert hat.

                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                  B 1 Antwort Letzte Antwort
                  0
                  • mickymM mickym

                    @mickym sagte in Hilfe bei debuggen einer übernommenen Funktion:

                    @bf0911 Was Du mal machen kannst ist - an Deine Node VOR der function Node eine Debug Node machen und dir das GANZE Nachrichtenobjekt dirausgeben lassen und hier in CodeTags einstellen, damit DU siehst, was für Eigenschaft Dein Nachrichtenobjekt hat.

                    Um ein Nachrichtenobjekt vollständig auszugeben, hängst Du wie gesagt eine Debug Node an die vorherige Node und gibst das vollständige Nachrichtenobjekt aus:

                    Das debug Tab ist das mit dem Käfer (Bug).

                    8ee4d433-3ca1-4c9a-b53c-29ed627fbcd1-image.png

                    Der Vorteil an einem Flow ist nun - dass nach jedem Schritt / node - also auch nach der Change Node, die wir erstellt haben, eine Debug Node anhängen können und bei Bedarf sehen können, wenn sich was verändert hat.

                    B Offline
                    B Offline
                    BF0911
                    schrieb am zuletzt editiert von
                    #22

                    @mickym

                    Hier der Debug-Output.

                    {"payload":7.44,"topic":"esphome.0.F4CFA2D0A156.Sensor.2835673629.state","_msgid":"133efcbf8d3a671e","_event":"node:242d9d62b7b4c44a","acknowledged":true,"timestamp":1715429688000,"lastchange":1715429522976,"mydate":"Sat May 11 2024","myymd":"2024-05-11","myyear":"2024","mymonth":"May","mymonthn":"05","mydom":"11","mydoy":"132","myday":"Sat","myhourpm":"2","myhour":"14","mytime":"14:14","mytimes":"14:14:48","myminute":"14","myminutes":"14:48","mysecond":"48","mymillis":"893","myepoch":"1715429688893","myrawdate":"2024-05-11T12:14:48.893Z","mypm":"PM"}
                    

                    Ich bin heute noch so ca. bis 15:30 Uhr am Rechner und dann leider morgen vormittag wieder.

                    mickymM 2 Antworten Letzte Antwort
                    0
                    • B BF0911

                      @mickym

                      Hier der Debug-Output.

                      {"payload":7.44,"topic":"esphome.0.F4CFA2D0A156.Sensor.2835673629.state","_msgid":"133efcbf8d3a671e","_event":"node:242d9d62b7b4c44a","acknowledged":true,"timestamp":1715429688000,"lastchange":1715429522976,"mydate":"Sat May 11 2024","myymd":"2024-05-11","myyear":"2024","mymonth":"May","mymonthn":"05","mydom":"11","mydoy":"132","myday":"Sat","myhourpm":"2","myhour":"14","mytime":"14:14","mytimes":"14:14:48","myminute":"14","myminutes":"14:48","mysecond":"48","mymillis":"893","myepoch":"1715429688893","myrawdate":"2024-05-11T12:14:48.893Z","mypm":"PM"}
                      

                      Ich bin heute noch so ca. bis 15:30 Uhr am Rechner und dann leider morgen vormittag wieder.

                      mickymM Online
                      mickymM Online
                      mickym
                      Most Active
                      schrieb am zuletzt editiert von mickym
                      #23

                      @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                      {"payload":7.44,"topic":"esphome.0.F4CFA2D0A156.Sensor.2835673629.state","_msgid":"133efcbf8d3a671e","_event":"node:242d9d62b7b4c44a","acknowledged":true,"timestamp":1715429688000,"lastchange":1715429522976,"mydate":"Sat May 11 2024","myymd":"2024-05-11","myyear":"2024","mymonth":"May","mymonthn":"05","mydom":"11","mydoy":"132","myday":"Sat","myhourpm":"2","myhour":"14","mytime":"14:14","mytimes":"14:14:48","myminute":"14","myminutes":"14:48","mysecond":"48","mymillis":"893","myepoch":"1715429688893","myrawdate":"2024-05-11T12:14:48.893Z","mypm":"PM"}

                      Na wahrscheinlich bist Du in der Zeile etwas verrutscht, da Du eine payload- unter der payload hast.

                      Schaut Deine Debugausgabe so aus, dass die payload einklappbar ist oder so wie in der 2. Ausgabe?

                      e0317ace-a802-4995-ac43-1744b738633d-image.png

                      Ich glaube eher wie in der 2. Ausgabe, da Du nur dort direkt in der function node auf msg.myhour referenzieren kannst.
                      Allerdings fehlt mit mir das payload objekt. - das ist ja nur eine Zahl.

                      Diese Zeile:

                      msg.payload.ph = Number((msg.payload.ph_current + 0.2).toFixed(2));

                      weißt aber darauf hin, dass Deine payload ein Objekt sein muss.

                      Also entweder ist das nicht das Nachrichtenobjekt was unmittelbar in die function NOde kommt, oder der Code Deiner function Node ist nicht vollständig?

                      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                      B 1 Antwort Letzte Antwort
                      0
                      • B BF0911

                        @mickym

                        Hier der Debug-Output.

                        {"payload":7.44,"topic":"esphome.0.F4CFA2D0A156.Sensor.2835673629.state","_msgid":"133efcbf8d3a671e","_event":"node:242d9d62b7b4c44a","acknowledged":true,"timestamp":1715429688000,"lastchange":1715429522976,"mydate":"Sat May 11 2024","myymd":"2024-05-11","myyear":"2024","mymonth":"May","mymonthn":"05","mydom":"11","mydoy":"132","myday":"Sat","myhourpm":"2","myhour":"14","mytime":"14:14","mytimes":"14:14:48","myminute":"14","myminutes":"14:48","mysecond":"48","mymillis":"893","myepoch":"1715429688893","myrawdate":"2024-05-11T12:14:48.893Z","mypm":"PM"}
                        

                        Ich bin heute noch so ca. bis 15:30 Uhr am Rechner und dann leider morgen vormittag wieder.

                        mickymM Online
                        mickymM Online
                        mickym
                        Most Active
                        schrieb am zuletzt editiert von
                        #24

                        @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                        Ich bin heute noch so ca. bis 15:30 Uhr am Rechner und dann leider morgen vormittag wieder.

                        Na ich dann wahrscheinlich erst am Abend wieder, melde Dich einfach via chat - musst Du ja nicht alles an einem Tag lernen. Jedenfalls muss die payload ein Objekt sein, dass da rein kommt und nicht nur eine Zahl (7.44), sprich die payload wurde bereits geändert.

                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                        1 Antwort Letzte Antwort
                        0
                        • mickymM mickym

                          @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                          {"payload":7.44,"topic":"esphome.0.F4CFA2D0A156.Sensor.2835673629.state","_msgid":"133efcbf8d3a671e","_event":"node:242d9d62b7b4c44a","acknowledged":true,"timestamp":1715429688000,"lastchange":1715429522976,"mydate":"Sat May 11 2024","myymd":"2024-05-11","myyear":"2024","mymonth":"May","mymonthn":"05","mydom":"11","mydoy":"132","myday":"Sat","myhourpm":"2","myhour":"14","mytime":"14:14","mytimes":"14:14:48","myminute":"14","myminutes":"14:48","mysecond":"48","mymillis":"893","myepoch":"1715429688893","myrawdate":"2024-05-11T12:14:48.893Z","mypm":"PM"}

                          Na wahrscheinlich bist Du in der Zeile etwas verrutscht, da Du eine payload- unter der payload hast.

                          Schaut Deine Debugausgabe so aus, dass die payload einklappbar ist oder so wie in der 2. Ausgabe?

                          e0317ace-a802-4995-ac43-1744b738633d-image.png

                          Ich glaube eher wie in der 2. Ausgabe, da Du nur dort direkt in der function node auf msg.myhour referenzieren kannst.
                          Allerdings fehlt mit mir das payload objekt. - das ist ja nur eine Zahl.

                          Diese Zeile:

                          msg.payload.ph = Number((msg.payload.ph_current + 0.2).toFixed(2));

                          weißt aber darauf hin, dass Deine payload ein Objekt sein muss.

                          Also entweder ist das nicht das Nachrichtenobjekt was unmittelbar in die function NOde kommt, oder der Code Deiner function Node ist nicht vollständig?

                          B Offline
                          B Offline
                          BF0911
                          schrieb am zuletzt editiert von
                          #25

                          @mickym

                          {"payload":7.41,"topic":"esphome.0.F4CFA2D0A156.Sensor.2835673629.state","_msgid":"f2e56b586c288cd7","_event":"node:242d9d62b7b4c44a","acknowledged":true,"timestamp":1715432588486,"lastchange":1715432408502}
                          

                          So sieht das aus. Hatte mich mit dem Debug vertan.

                          mickymM 1 Antwort Letzte Antwort
                          0
                          • B BF0911

                            @mickym

                            {"payload":7.41,"topic":"esphome.0.F4CFA2D0A156.Sensor.2835673629.state","_msgid":"f2e56b586c288cd7","_event":"node:242d9d62b7b4c44a","acknowledged":true,"timestamp":1715432588486,"lastchange":1715432408502}
                            

                            So sieht das aus. Hatte mich mit dem Debug vertan.

                            mickymM Online
                            mickymM Online
                            mickym
                            Most Active
                            schrieb am zuletzt editiert von mickym
                            #26

                            @bf0911 Nein das kann es auch nicht sein. Zeig mal Dein Flow, wo Du die Debug Node hingemacht hast.
                            Das erste war schon besser, aber wie gesagt Deine payload muss ein Objekt sein. Es schaut nun so aus, als ob Du das iobroker Objekt ausgibst und nicht das Nachrichtenobjekt.

                            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                            B 1 Antwort Letzte Antwort
                            0
                            • mickymM mickym

                              @bf0911 Nein das kann es auch nicht sein. Zeig mal Dein Flow, wo Du die Debug Node hingemacht hast.
                              Das erste war schon besser, aber wie gesagt Deine payload muss ein Objekt sein. Es schaut nun so aus, als ob Du das iobroker Objekt ausgibst und nicht das Nachrichtenobjekt.

                              B Offline
                              B Offline
                              BF0911
                              schrieb am zuletzt editiert von
                              #27

                              @mickym Screenshot 2024-05-11 150607.png

                              debug3 und die Funktion ist Prüflogik

                              mickymM 1 Antwort Letzte Antwort
                              0
                              • B BF0911

                                @mickym Screenshot 2024-05-11 150607.png

                                debug3 und die Funktion ist Prüflogik

                                mickymM Online
                                mickymM Online
                                mickym
                                Most Active
                                schrieb am zuletzt editiert von mickym
                                #28

                                @bf0911 Na das kann es nicht sein. Ist denn der Code Deiner function node vollständig oder wird da die payload noch verschoben.

                                Steht da so eine Zeile wie

                                msg.payload.ph_current = msg.payload
                                

                                oder wie ist denn Deine iobroker-get Node konfiguriert?

                                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                mickymM 1 Antwort Letzte Antwort
                                0
                                • mickymM mickym

                                  @bf0911 Na das kann es nicht sein. Ist denn der Code Deiner function node vollständig oder wird da die payload noch verschoben.

                                  Steht da so eine Zeile wie

                                  msg.payload.ph_current = msg.payload
                                  

                                  oder wie ist denn Deine iobroker-get Node konfiguriert?

                                  mickymM Online
                                  mickymM Online
                                  mickym
                                  Most Active
                                  schrieb am zuletzt editiert von mickym
                                  #29

                                  Ok ich verabschiede mich dann mal - und wir können dann weiter machen, wenn Du wieder da bist.

                                  mach mal in Deine function Node - zum Debuggen noch folgende Zeile an 1. Stelle bzw. nach dem Setzen der Variablen rein und schau was im Debug Fenster auftaucht.

                                  node.warn(msg.payload.ph_current);
                                  

                                  Wenn Du das siehst, dann sehen wir ja woher das kommt bzw. ob die Eigenschaft definiert ist:

                                  2b83ae98-6398-479d-9fd0-eebf768099aa-image.png

                                  Am Besten Du fügst das node.warn(...) direkt vor die Anweisung, die die msg.payload.ph setzt. Eventuell hast Du die ganze function Node an die falsche Stelle gesetzt

                                  febdb434-05e4-49b5-8055-e5e15be1801d-image.png

                                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                  1 Antwort Letzte Antwort
                                  0
                                  • mickymM Online
                                    mickymM Online
                                    mickym
                                    Most Active
                                    schrieb am zuletzt editiert von mickym
                                    #30

                                    Ansonsten wenn das der Fehler ist, dass dein flow nicht funktioniert, dann setze hinter die iobroker get node eine Change node und verschiebe die payload auf payload.ph_current.

                                    ich glaube ich weiß wo das Problem liegt. mit deiner iobroker get überschreibst du deine payload, die du von einem anderen Flow hast und deshalb funktioniert deine function node nicht mehr, weil du dein Objekt überschrieben, weggeschmissen hast. wenn du eine debug node direkt an die link in node machst, ist das objekt vielleicht noch vorhanden.

                                    Am besten du machst eine debug node vor und nach der iobroker get node hin und du siehst den unterschied

                                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                    1 Antwort Letzte Antwort
                                    0
                                    • mickymM Online
                                      mickymM Online
                                      mickym
                                      Most Active
                                      schrieb am zuletzt editiert von mickym
                                      #31

                                      @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                                      Um Dir kurzfristig quick&dirty zu helfen,

                                      änderst Du Deinen Code einfach wie folgt:

                                      var FilterPumpeStatus = global.get('FilterPumpe'); 
                                      var DurchflussschalterStatus = global.get('Paddelschalter');
                                      var PH_Pumpe_Laufzeit_Tag = global.get('PH_Pumpe_Laufzeit_Tag'); 
                                      var PH_Pumpe_Pause = global.get('PH_Pumpe_Pause'); 
                                      var PH_Pumpe_Laufzeit_ms = flow.get('PH_Pumpe_Laufzeit_sec') * 1000; 
                                      var Chlor_Pumpe_Status = global.get('Chlor_Pumpe'); 
                                      var PoolAutomatikModus = global.get('PoolAutomatikModus'); 
                                      var PH_Pumpe_MaxTagesLaufzeit_min = flow.get('PH_Pumpe_MaxTagesLaufzeit_min'); 
                                      var PH_Pumpe_Grenzwert = flow.get('PH_Pumpe_Grenzwert'); 
                                      var PH_Pumpe_Automatik =  flow.get('PH_Pumpe_Automatik');
                                      var PH_Pumpe_Session_Laufzeit =  flow.get('PH_Pumpe_Session_Laufzeit');
                                      
                                      var myStunde = Number(msg.myhour);
                                      msg.payload.ph = Number((msg.ph_current + 0.2).toFixed(2));
                                      
                                      flow.set('PH_Actual',msg.payload.ph); 
                                      flow.set('ORP_Actual',msg.payload.orp_current); 
                                      
                                      if (myStunde >= 20 && myStunde <= 23  )
                                      {
                                      
                                      msg.delay = PH_Pumpe_Laufzeit_ms;
                                      
                                      // for test without Logic
                                      //return [msg];
                                      
                                      if (PoolAutomatikModus == "ON" && PH_Pumpe_Automatik == "ON")
                                      {
                                              if (msg.payload.ph_current < 6 || msg.payload.ph_current > 8 )
                                              {
                                                  return [null];
                                              }
                                              else if (msg.payload.ph_current >= PH_Pumpe_Grenzwert && FilterPumpeStatus == "ON" && PH_Pumpe_Laufzeit_Tag < PH_Pumpe_MaxTagesLaufzeit_min && PH_Pumpe_Pause == "NO" && Chlor_Pumpe_Status == "OFF" && DurchflussschalterStatus == "ON" && PH_Pumpe_Session_Laufzeit > 10) 
                                                  {
                                                      return [msg];
                                                  }
                                              else
                                                  {
                                                      return [null];
                                                  }
                                      }
                                      else
                                       {
                                          return [null];
                                      }
                                      }
                                      else
                                       {
                                          return [null];
                                      }
                                      
                                      
                                      
                                      

                                      19e44ed6-094e-4443-a326-7df0ad02530d-image.png

                                      Der Rest muss das originale payload Objekt bringen. Und damit Dein payload Objekt nicht mehr überschrieben wird, speicherst Du den ausgelesenen ph-Wert nicht in der payload, sondern in ph_current.

                                      953bd840-b489-4e7a-9178-fa3d113ed840-image.png

                                      Die anderen payload Eigenschaften müssen dann aus Deinen anderen Flowteilen kommen, also aus der link-in Node.

                                      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                      B 1 Antwort Letzte Antwort
                                      0
                                      • mickymM mickym

                                        @bf0911 sagte in Hilfe bei debuggen einer übernommenen Funktion:

                                        Um Dir kurzfristig quick&dirty zu helfen,

                                        änderst Du Deinen Code einfach wie folgt:

                                        var FilterPumpeStatus = global.get('FilterPumpe'); 
                                        var DurchflussschalterStatus = global.get('Paddelschalter');
                                        var PH_Pumpe_Laufzeit_Tag = global.get('PH_Pumpe_Laufzeit_Tag'); 
                                        var PH_Pumpe_Pause = global.get('PH_Pumpe_Pause'); 
                                        var PH_Pumpe_Laufzeit_ms = flow.get('PH_Pumpe_Laufzeit_sec') * 1000; 
                                        var Chlor_Pumpe_Status = global.get('Chlor_Pumpe'); 
                                        var PoolAutomatikModus = global.get('PoolAutomatikModus'); 
                                        var PH_Pumpe_MaxTagesLaufzeit_min = flow.get('PH_Pumpe_MaxTagesLaufzeit_min'); 
                                        var PH_Pumpe_Grenzwert = flow.get('PH_Pumpe_Grenzwert'); 
                                        var PH_Pumpe_Automatik =  flow.get('PH_Pumpe_Automatik');
                                        var PH_Pumpe_Session_Laufzeit =  flow.get('PH_Pumpe_Session_Laufzeit');
                                        
                                        var myStunde = Number(msg.myhour);
                                        msg.payload.ph = Number((msg.ph_current + 0.2).toFixed(2));
                                        
                                        flow.set('PH_Actual',msg.payload.ph); 
                                        flow.set('ORP_Actual',msg.payload.orp_current); 
                                        
                                        if (myStunde >= 20 && myStunde <= 23  )
                                        {
                                        
                                        msg.delay = PH_Pumpe_Laufzeit_ms;
                                        
                                        // for test without Logic
                                        //return [msg];
                                        
                                        if (PoolAutomatikModus == "ON" && PH_Pumpe_Automatik == "ON")
                                        {
                                                if (msg.payload.ph_current < 6 || msg.payload.ph_current > 8 )
                                                {
                                                    return [null];
                                                }
                                                else if (msg.payload.ph_current >= PH_Pumpe_Grenzwert && FilterPumpeStatus == "ON" && PH_Pumpe_Laufzeit_Tag < PH_Pumpe_MaxTagesLaufzeit_min && PH_Pumpe_Pause == "NO" && Chlor_Pumpe_Status == "OFF" && DurchflussschalterStatus == "ON" && PH_Pumpe_Session_Laufzeit > 10) 
                                                    {
                                                        return [msg];
                                                    }
                                                else
                                                    {
                                                        return [null];
                                                    }
                                        }
                                        else
                                         {
                                            return [null];
                                        }
                                        }
                                        else
                                         {
                                            return [null];
                                        }
                                        
                                        
                                        
                                        

                                        19e44ed6-094e-4443-a326-7df0ad02530d-image.png

                                        Der Rest muss das originale payload Objekt bringen. Und damit Dein payload Objekt nicht mehr überschrieben wird, speicherst Du den ausgelesenen ph-Wert nicht in der payload, sondern in ph_current.

                                        953bd840-b489-4e7a-9178-fa3d113ed840-image.png

                                        Die anderen payload Eigenschaften müssen dann aus Deinen anderen Flowteilen kommen, also aus der link-in Node.

                                        B Offline
                                        B Offline
                                        BF0911
                                        schrieb am zuletzt editiert von
                                        #32

                                        @mickym

                                        So, kurze Rückmeldung, mit leider sehr wenig Zeit heute.

                                        Ich bekomme mit der node.warn auch undefined.

                                        Dann hab ich die Change-Node eingefügt, siehe Bild.

                                        Und deinen Code ebenfalls.

                                        Screenshot 2024-05-12 141546.png

                                        B 1 Antwort Letzte Antwort
                                        0
                                        • B BF0911

                                          @mickym

                                          So, kurze Rückmeldung, mit leider sehr wenig Zeit heute.

                                          Ich bekomme mit der node.warn auch undefined.

                                          Dann hab ich die Change-Node eingefügt, siehe Bild.

                                          Und deinen Code ebenfalls.

                                          Screenshot 2024-05-12 141546.png

                                          B Offline
                                          B Offline
                                          BF0911
                                          schrieb am zuletzt editiert von
                                          #33

                                          Es scheint aber auch außerhalb der Funktion einiges im Argen zu liegen.

                                          Der PoolAutomatikModus macht auch nicht das was, er soll.

                                          Das aber nur am Rande.

                                          mickymM 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          367

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe