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.2k

Hilfe bei debuggen einer übernommenen Funktion

Geplant Angeheftet Gesperrt Verschoben Node-Red
157 Beiträge 2 Kommentatoren 15.0k 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.
  • 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
                      • B BF0911

                        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 Online
                        mickymM Online
                        mickym
                        Most Active
                        schrieb am zuletzt editiert von
                        #34

                        @bf0911 Weißt Du die Frage ist halt immer, warum macht "ihr" das immer mit dem zusammenkopieren von Codefragmenten und probiert nicht mal selbst von Anfang an.

                        Ich habe vor 3 Jahren auch hier mit einem User eine Poolsteuerung mit NodeRed implementiert.

                        Schau mal, ob das in etwa vergleichbar ist:
                        https://forum.iobroker.net/topic/43480/gelöst-poolsteuerung-anfänger-braucht-e-hilfe

                        Ich will Dich damit nicht ermutigen, das genauso zu kopieren, aber vielleicht hast Du ja den Mut, so was von vorne selbst zu beginnen. Ich würde Dich dabei genauso unterstützen wie damals.

                        Ich halte das ggf. für sinnvoller, als diese Dinge einfach zu kopieren. Wenn Du es selbst machst, dann kannst Du es von Beginn nach Deinen Vorstellungen implementieren.

                        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 Weißt Du die Frage ist halt immer, warum macht "ihr" das immer mit dem zusammenkopieren von Codefragmenten und probiert nicht mal selbst von Anfang an.

                          Ich habe vor 3 Jahren auch hier mit einem User eine Poolsteuerung mit NodeRed implementiert.

                          Schau mal, ob das in etwa vergleichbar ist:
                          https://forum.iobroker.net/topic/43480/gelöst-poolsteuerung-anfänger-braucht-e-hilfe

                          Ich will Dich damit nicht ermutigen, das genauso zu kopieren, aber vielleicht hast Du ja den Mut, so was von vorne selbst zu beginnen. Ich würde Dich dabei genauso unterstützen wie damals.

                          Ich halte das ggf. für sinnvoller, als diese Dinge einfach zu kopieren. Wenn Du es selbst machst, dann kannst Du es von Beginn nach Deinen Vorstellungen implementieren.

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

                          @mickym

                          Tatsächlich aus Bequemlichkeit. Ich bin davon ausgegangen, dass ich den Flow nur auf meinen Gegebenheiten (Datenpunkte etc.) anpassen muss und es dann laufen würde.

                          GRundsätzlich bin ich gerne bereit, das Ganze selbst und von vorne aufzubauen.

                          Die verlinkte Poolsteuerung muss mich mir mal in Ruhe anschauen, wobei ich auf den ersten Blick gesehen habe, dass es sich dort eher um die "Wärme-Steuerung" handelt.

                          B 1 Antwort Letzte Antwort
                          0
                          • B BF0911

                            @mickym

                            Tatsächlich aus Bequemlichkeit. Ich bin davon ausgegangen, dass ich den Flow nur auf meinen Gegebenheiten (Datenpunkte etc.) anpassen muss und es dann laufen würde.

                            GRundsätzlich bin ich gerne bereit, das Ganze selbst und von vorne aufzubauen.

                            Die verlinkte Poolsteuerung muss mich mir mal in Ruhe anschauen, wobei ich auf den ersten Blick gesehen habe, dass es sich dort eher um die "Wärme-Steuerung" handelt.

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

                            Ich hab mal komplett neu anzufangen:

                            Screenshot 2024-05-13 074154.png

                            Hier soll der Automatik-Modus gesetzt werden und falls dieser ausgeschaltet wird, sollen die Chlor- und Ph-Pumpe sofort und die Filter-Pumpe nach einer 1 Minute stoppen.

                            Dafür habe ich den Switch wie folgt gesetzt:

                            Screenshot 2024-05-13 074359.png

                            B mickymM 2 Antworten Letzte Antwort
                            0
                            • B BF0911

                              Ich hab mal komplett neu anzufangen:

                              Screenshot 2024-05-13 074154.png

                              Hier soll der Automatik-Modus gesetzt werden und falls dieser ausgeschaltet wird, sollen die Chlor- und Ph-Pumpe sofort und die Filter-Pumpe nach einer 1 Minute stoppen.

                              Dafür habe ich den Switch wie folgt gesetzt:

                              Screenshot 2024-05-13 074359.png

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

                              weiter gehts:

                              Screenshot 2024-05-13 101526.png

                              Der erste Teil wurde nochmal etwas optimiert (Aus meiner Sicht) und soll den Automatik-Modus setzen.

                              Der zweite Teil soll meine Filter-Pumpe in Abhängigkeit des Zeitplans und Pool-Automatik "aktiv" steuern.

                              Wenn der Zeitplan ein "false" sendet, soll noch überprüft werden, ob Ph- und Chlor-Pumpe gerade laufen.

                              B 1 Antwort Letzte Antwort
                              0
                              • B BF0911

                                weiter gehts:

                                Screenshot 2024-05-13 101526.png

                                Der erste Teil wurde nochmal etwas optimiert (Aus meiner Sicht) und soll den Automatik-Modus setzen.

                                Der zweite Teil soll meine Filter-Pumpe in Abhängigkeit des Zeitplans und Pool-Automatik "aktiv" steuern.

                                Wenn der Zeitplan ein "false" sendet, soll noch überprüft werden, ob Ph- und Chlor-Pumpe gerade laufen.

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

                                Was ist eigentlich genau der Unterschied zwischen iobroker.in und iobroker.get?

                                Und wann nutzt man sinnvollerweise was?

                                mickymM 1 Antwort Letzte Antwort
                                0
                                • B BF0911

                                  Ich hab mal komplett neu anzufangen:

                                  Screenshot 2024-05-13 074154.png

                                  Hier soll der Automatik-Modus gesetzt werden und falls dieser ausgeschaltet wird, sollen die Chlor- und Ph-Pumpe sofort und die Filter-Pumpe nach einer 1 Minute stoppen.

                                  Dafür habe ich den Switch wie folgt gesetzt:

                                  Screenshot 2024-05-13 074359.png

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

                                  @bf0911 Na das ist doch schön, dass angefangen hast. Ich sehe nun auch, dass Du das NodeRed Dashboard nutzen willst.

                                  Ein paar Verbesserungsvorschläge habe ich bereits bzw. sind mir noch nicht klar.

                                  1. Standardmässig wird in dem Adapter nun (und das ist auch gut so), die Option in Zeichenfolgen zu konvertieren ausgeschaltet.

                                  bf2ca028-4755-4eb5-9dcf-d3a25bb9a6b6-image.png

                                  Das ist auch richtig so, damit Du richtige Datentypen verwenden kannst und nicht dauern hin und her konvertieren musst.

                                  1. Wenn Du dann allerdings auf Booleans prüfst und musst Du auch den richtigen Datentyp verwenden.

                                  957d7536-05ff-4b86-bd19-fbcb538d3a5e-image.png

                                  Hier vergleichst Du mit einem String und nicht mit einem Logikwert.

                                  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 Na das ist doch schön, dass angefangen hast. Ich sehe nun auch, dass Du das NodeRed Dashboard nutzen willst.

                                    Ein paar Verbesserungsvorschläge habe ich bereits bzw. sind mir noch nicht klar.

                                    1. Standardmässig wird in dem Adapter nun (und das ist auch gut so), die Option in Zeichenfolgen zu konvertieren ausgeschaltet.

                                    bf2ca028-4755-4eb5-9dcf-d3a25bb9a6b6-image.png

                                    Das ist auch richtig so, damit Du richtige Datentypen verwenden kannst und nicht dauern hin und her konvertieren musst.

                                    1. Wenn Du dann allerdings auf Booleans prüfst und musst Du auch den richtigen Datentyp verwenden.

                                    957d7536-05ff-4b86-bd19-fbcb538d3a5e-image.png

                                    Hier vergleichst Du mit einem String und nicht mit einem Logikwert.

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

                                    @mickym

                                    Diese Option ist bei mir auch ausgeschaltet.

                                    Dann muss das vermutlich so sein?

                                    Screenshot 2024-05-13 113846.png

                                    mickymM 1 Antwort Letzte Antwort
                                    0
                                    • B BF0911

                                      Was ist eigentlich genau der Unterschied zwischen iobroker.in und iobroker.get?

                                      Und wann nutzt man sinnvollerweise was?

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

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

                                      Was ist eigentlich genau der Unterschied zwischen iobroker.in und iobroker.get?

                                      Und wann nutzt man sinnvollerweise was?

                                      Eigentlich brauchst Du nicht alles über globale Variablen regeln.

                                      Bei der iobroker.in Node siehst Du, dass die nur einen Ausgang aber keinen Eingang hat.

                                      c0580fe9-c089-46f9-aeaf-a91dceb35490-image.png

                                      Sprich der Flow wird getriggert oder ausgelöst durch eine Aktualisierung oder Änderung eines Datenpunktes im iobroker.

                                      Da Du nicht soviele globale Variablen brauchst (die müssen ja auch bei jedem Neustart gesetzt werden), kannst Du, wenn ein Flow getriggert wurde, die mit der get Node andere Datenpunkte aus dem iobroker auslesen. Zum Beispiel ob der Automatik Modus eingeschaltet ist, dann muss man das nicht über globale Variablen lösen. Das belastet das System etwas mehr, weil quasi immer wieder der iobroker abgefragt wird - also hängt ein bisschen von der Häufigkeit ab.

                                      Sprich wenn sich z.Bsp Dein ph Wert ändert und dieser triggern soll, dann verwendest Du einen iobroker-In Node. Möchtest Du dann eine Aktion in Abhängigkeit eines Logikwertes prüfen, nimmst Du anschliessend eine iobroker-get Node und liest den Wert aktiv zu dem Zeitpunkt aus, zudem Dein ph Wert sich geändert hat.

                                      Wichtig ist, dass Du mit der get Node nicht die payload - deiner iobroker-IN Node überschreibst!!!

                                      f269e91c-41b0-4961-be70-5349f1274785-image.png

                                      Deshalb musst Du den Wert mit der ausgelesenen Eigenschaft nicht der Nachrichteneigenschaft "payload" sondern einem anderen Eigenschaft zuweisen. Hier active.

                                      a9968b11-769e-4b75-8966-2ab4cc12760b-image.png

                                      Damit enthält Dein Nachrichtenobjekt beide Eigenschaften und Du kannst beide Eigenschaften zu Vergleichen nutzen.

                                      Hier zum Import:

                                      [{"id":"38663d6d60bd9893","type":"ioBroker in","z":"289f539dcc33814e","name":"","attrname":"payload","topic":"0_userdata.0.Test.Zahl","payloadType":"value","onlyack":"","func":"all","gap":"","fireOnStart":"true","outFormat":"MQTT","x":280,"y":6700,"wires":[["802306ee3fdee39f"]]},{"id":"802306ee3fdee39f","type":"ioBroker get","z":"289f539dcc33814e","name":"","topic":"0_userdata.0.Test.aktiv","attrname":"active","payloadType":"value","errOnInvalidState":"nothing","x":570,"y":6700,"wires":[["527348828b6c739d"]]},{"id":"527348828b6c739d","type":"debug","z":"289f539dcc33814e","name":"Ergebnis","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":780,"y":6700,"wires":[]}]
                                      

                                      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

                                        Diese Option ist bei mir auch ausgeschaltet.

                                        Dann muss das vermutlich so sein?

                                        Screenshot 2024-05-13 113846.png

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

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

                                        @mickym

                                        Diese Option ist bei mir auch ausgeschaltet.

                                        Dann muss das vermutlich so sein?

                                        Screenshot 2024-05-13 113846.png

                                        Korrekt!!!

                                        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:

                                          Was ist eigentlich genau der Unterschied zwischen iobroker.in und iobroker.get?

                                          Und wann nutzt man sinnvollerweise was?

                                          Eigentlich brauchst Du nicht alles über globale Variablen regeln.

                                          Bei der iobroker.in Node siehst Du, dass die nur einen Ausgang aber keinen Eingang hat.

                                          c0580fe9-c089-46f9-aeaf-a91dceb35490-image.png

                                          Sprich der Flow wird getriggert oder ausgelöst durch eine Aktualisierung oder Änderung eines Datenpunktes im iobroker.

                                          Da Du nicht soviele globale Variablen brauchst (die müssen ja auch bei jedem Neustart gesetzt werden), kannst Du, wenn ein Flow getriggert wurde, die mit der get Node andere Datenpunkte aus dem iobroker auslesen. Zum Beispiel ob der Automatik Modus eingeschaltet ist, dann muss man das nicht über globale Variablen lösen. Das belastet das System etwas mehr, weil quasi immer wieder der iobroker abgefragt wird - also hängt ein bisschen von der Häufigkeit ab.

                                          Sprich wenn sich z.Bsp Dein ph Wert ändert und dieser triggern soll, dann verwendest Du einen iobroker-In Node. Möchtest Du dann eine Aktion in Abhängigkeit eines Logikwertes prüfen, nimmst Du anschliessend eine iobroker-get Node und liest den Wert aktiv zu dem Zeitpunkt aus, zudem Dein ph Wert sich geändert hat.

                                          Wichtig ist, dass Du mit der get Node nicht die payload - deiner iobroker-IN Node überschreibst!!!

                                          f269e91c-41b0-4961-be70-5349f1274785-image.png

                                          Deshalb musst Du den Wert mit der ausgelesenen Eigenschaft nicht der Nachrichteneigenschaft "payload" sondern einem anderen Eigenschaft zuweisen. Hier active.

                                          a9968b11-769e-4b75-8966-2ab4cc12760b-image.png

                                          Damit enthält Dein Nachrichtenobjekt beide Eigenschaften und Du kannst beide Eigenschaften zu Vergleichen nutzen.

                                          Hier zum Import:

                                          [{"id":"38663d6d60bd9893","type":"ioBroker in","z":"289f539dcc33814e","name":"","attrname":"payload","topic":"0_userdata.0.Test.Zahl","payloadType":"value","onlyack":"","func":"all","gap":"","fireOnStart":"true","outFormat":"MQTT","x":280,"y":6700,"wires":[["802306ee3fdee39f"]]},{"id":"802306ee3fdee39f","type":"ioBroker get","z":"289f539dcc33814e","name":"","topic":"0_userdata.0.Test.aktiv","attrname":"active","payloadType":"value","errOnInvalidState":"nothing","x":570,"y":6700,"wires":[["527348828b6c739d"]]},{"id":"527348828b6c739d","type":"debug","z":"289f539dcc33814e","name":"Ergebnis","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":780,"y":6700,"wires":[]}]
                                          

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

                                          @mickym

                                          Das habt ich nur so halb verstanden.

                                          Iobroker.in löst immer aus, wenn das "Objekt" geändert wurde (Filter-Pumpe ein oder ausgeschaltet?). Das habe ich hoffentlich richtig verstanden.

                                          Das mit dem get leider nicht so. mir leuchtet das Beispiel mit der Automatik nicht so ein.

                                          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

                                          881

                                          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