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. Blockly
  5. Skript löst "fälschlicherweise" aus

NEWS

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

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

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

Skript löst "fälschlicherweise" aus

Geplant Angeheftet Gesperrt Verschoben Blockly
24 Beiträge 4 Kommentatoren 571 Aufrufe 4 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.
  • ? Ein ehemaliger Benutzer

    @codierknecht man sieht schon am Zeitstempel ‚zuletzt geändert‘ das sich da inhaltlich nichts geändert hat sondern nur aktualisiert wurde. Daher sollte der trigger garnicht auslösen. Wäre interessant zu wissen ob es auch bei anderen Datenpunkten der Fall ist oder nur hier. Habt ihr mal den Export blockly für mich damit ich auch mal testen kann?

    David G.D Online
    David G.D Online
    David G.
    schrieb am zuletzt editiert von
    #11

    @ciddi89

    In meinem Eingangspost.

    @paul53 hatte noch eine Frage.
    Kann ich aber nichts mit anfangen.....

    @paul53 sagte in Skript löst "fälschlicherweise" aus:

    @david-g sagte: Am ehsten im Javascript Adapter oder?

    Eher nicht. Es muss ein besonderes Verhalten des Datenpunktes des Watcher-Adapters sein. Hat er ein state.expire?

    Zeigt eure Lovelace-Visualisierung klick
    (Auch ideal um sich Anregungen zu holen)

    Meine Tabellen für eure Visualisierung klick

    ? 1 Antwort Letzte Antwort
    0
    • ? Ein ehemaliger Benutzer

      @codierknecht man sieht schon am Zeitstempel ‚zuletzt geändert‘ das sich da inhaltlich nichts geändert hat sondern nur aktualisiert wurde. Daher sollte der trigger garnicht auslösen. Wäre interessant zu wissen ob es auch bei anderen Datenpunkten der Fall ist oder nur hier. Habt ihr mal den Export blockly für mich damit ich auch mal testen kann?

      CodierknechtC Offline
      CodierknechtC Offline
      Codierknecht
      Developer Most Active
      schrieb am zuletzt editiert von Codierknecht
      #12

      @ciddi89
      Das ist das Ergebnis:
      5c2ae882-223a-4cff-a44f-9391afe3e9be-grafik.png

      Edit: Aktualisierungsintervall des Adapters steht auf 30 Sekunden!

      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

      Proxmox 9.1.1 LXC|8 GB|Core i7-6700
      HmIP|ZigBee|Tasmota|Unifi
      Zabbix Certified Specialist
      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

      paul53P 1 Antwort Letzte Antwort
      0
      • David G.D David G.

        @ciddi89

        In meinem Eingangspost.

        @paul53 hatte noch eine Frage.
        Kann ich aber nichts mit anfangen.....

        @paul53 sagte in Skript löst "fälschlicherweise" aus:

        @david-g sagte: Am ehsten im Javascript Adapter oder?

        Eher nicht. Es muss ein besonderes Verhalten des Datenpunktes des Watcher-Adapters sein. Hat er ein state.expire?

        ? Offline
        ? Offline
        Ein ehemaliger Benutzer
        schrieb am zuletzt editiert von
        #13

        @david-g ne hat er nicht. Und alle Datenpunkte werden gleich erstellt. Daher codemäßig ist da kein unterschied.

        1 Antwort Letzte Antwort
        0
        • CodierknechtC Codierknecht

          @ciddi89
          Das ist das Ergebnis:
          5c2ae882-223a-4cff-a44f-9391afe3e9be-grafik.png

          Edit: Aktualisierungsintervall des Adapters steht auf 30 Sekunden!

          paul53P Offline
          paul53P Offline
          paul53
          schrieb am zuletzt editiert von
          #14

          @codierknecht sagte: Das ist das Ergebnis:

          Teste mal mit:

          on('device-watcher.0.lowBatteryList', function(dp) {
              log(dp.oldState);
              log(dp.state);
          });
          

          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

          ? CodierknechtC 2 Antworten Letzte Antwort
          0
          • paul53P paul53

            @codierknecht sagte: Das ist das Ergebnis:

            Teste mal mit:

            on('device-watcher.0.lowBatteryList', function(dp) {
                log(dp.oldState);
                log(dp.state);
            });
            
            ? Offline
            ? Offline
            Ein ehemaliger Benutzer
            schrieb am zuletzt editiert von
            #15

            @paul53 said in Skript löst "fälschlicherweise" aus:

                                                                                                                                        on('device-watcher.0.lowBatteryList', function(dp) {                                                                                                                                                                                log(dp.oldState);                                                                                                                                                                                log(dp.state);                                                                                                                                                                            });
            
            23:42:57.860	info	javascript.0 (544) script.js.Vorlagen.Skript_1: {'val':[{'Device':'Büro Bewegungsmelder','Adapter':'Zigbee2MQTT','Battery':'21%'}],'ts':1676500962641,'ack':true,'lc':1676499209986,'from':'system.adapter.device-watcher.0','q':0,'user':'system.user.admin'}
            23:42:57.860	info	javascript.0 (544) script.js.Vorlagen.Skript_1: {'val':[{'Device':'Büro Bewegungsmelder','Adapter':'Zigbee2MQTT','Battery':'21%'}],'ts':1676500977819,'ack':true,'lc':1676499209986,'from':'system.adapter.device-watcher.0','q':0,'user':'system.user.admin'}
            
            paul53P 1 Antwort Letzte Antwort
            0
            • ? Ein ehemaliger Benutzer

              @paul53 said in Skript löst "fälschlicherweise" aus:

                                                                                                                                          on('device-watcher.0.lowBatteryList', function(dp) {                                                                                                                                                                                log(dp.oldState);                                                                                                                                                                                log(dp.state);                                                                                                                                                                            });
              
              23:42:57.860	info	javascript.0 (544) script.js.Vorlagen.Skript_1: {'val':[{'Device':'Büro Bewegungsmelder','Adapter':'Zigbee2MQTT','Battery':'21%'}],'ts':1676500962641,'ack':true,'lc':1676499209986,'from':'system.adapter.device-watcher.0','q':0,'user':'system.user.admin'}
              23:42:57.860	info	javascript.0 (544) script.js.Vorlagen.Skript_1: {'val':[{'Device':'Büro Bewegungsmelder','Adapter':'Zigbee2MQTT','Battery':'21%'}],'ts':1676500977819,'ack':true,'lc':1676499209986,'from':'system.adapter.device-watcher.0','q':0,'user':'system.user.admin'}
              
              paul53P Offline
              paul53P Offline
              paul53
              schrieb am zuletzt editiert von
              #16

              @ciddi89
              Außer ts alles identisch, also hätte nicht getriggert werden dürfen.

              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

              ? 1 Antwort Letzte Antwort
              0
              • paul53P paul53

                @ciddi89
                Außer ts alles identisch, also hätte nicht getriggert werden dürfen.

                ? Offline
                ? Offline
                Ein ehemaliger Benutzer
                schrieb am zuletzt editiert von
                #17

                @paul53 ja mein reden. Das ist wirklich sehr merkwürdig.

                CodierknechtC 1 Antwort Letzte Antwort
                0
                • David G.D Online
                  David G.D Online
                  David G.
                  schrieb am zuletzt editiert von
                  #18

                  Im Admin leuchten bei mir auch alle 10sek 4 Datenpunkte (wo es auch Sinn macht) grün auf.

                  Der hier betroffene ist nicht bei.

                  Somit scheint ja "theoretisch" alles zu stimmen.....

                  Zeigt eure Lovelace-Visualisierung klick
                  (Auch ideal um sich Anregungen zu holen)

                  Meine Tabellen für eure Visualisierung klick

                  1 Antwort Letzte Antwort
                  0
                  • paul53P paul53

                    @codierknecht sagte: Das ist das Ergebnis:

                    Teste mal mit:

                    on('device-watcher.0.lowBatteryList', function(dp) {
                        log(dp.oldState);
                        log(dp.state);
                    });
                    
                    CodierknechtC Offline
                    CodierknechtC Offline
                    Codierknecht
                    Developer Most Active
                    schrieb am zuletzt editiert von
                    #19

                    @paul53
                    Ich hab's gerade mal mit lowBatteryList und auch mit offlineList getestet. Beide Trigger werden passend zum eingestellten Aktualisierungsintervall des Adapters ausgeführt. Und wie bei @ciddi89 ändert sich nur ts.

                    Triggere ich dagegen auf lowBatteryCount bzw. offlineCount, passiert ... nix. Hier wird der Trigger dann tatsächlich - wie erwartet - nur ausgeführt, wenn sich etwas ändert.

                    "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                    Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                    HmIP|ZigBee|Tasmota|Unifi
                    Zabbix Certified Specialist
                    Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                    1 Antwort Letzte Antwort
                    0
                    • ? Ein ehemaliger Benutzer

                      @paul53 ja mein reden. Das ist wirklich sehr merkwürdig.

                      CodierknechtC Offline
                      CodierknechtC Offline
                      Codierknecht
                      Developer Most Active
                      schrieb am zuletzt editiert von Codierknecht
                      #20

                      @ciddi89
                      Was ist denn, wenn Du in writeDatapoints(adptName) aus dem hier:

                      // list battery low powered
                      if (this.lowBatteryPoweredCount === 0) {
                      	// if no device is count, write the JSON List with default value
                      	this.batteryLowPowered = [{ Device: '--none--', Adapter: '', Battery: '' }];
                      }
                      //write JSON list
                      await this.setStateAsync(`devices.${dpSubFolder}lowBatteryList`, {
                      	val: JSON.stringify(this.batteryLowPowered),
                      	ack: true,
                      });
                      
                      

                      Das hier machst:

                      // list battery low powered
                      if (this.lowBatteryPoweredCount === 0) {
                      	// if no device is count, write the JSON List with default value
                      	this.batteryLowPowered = [{ Device: '--none--', Adapter: '', Battery: '' }];
                      } else {
                        //write JSON list
                        await this.setStateAsync(`devices.${dpSubFolder}lowBatteryList`, {
                        	val: JSON.stringify(this.batteryLowPowered),
                        	ack: true,
                        });
                      }
                      

                      Das "umgeht" zwar nur das eigentliche Problem, sollte aber helfen.

                      "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                      Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                      HmIP|ZigBee|Tasmota|Unifi
                      Zabbix Certified Specialist
                      Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                      ? 1 Antwort Letzte Antwort
                      0
                      • CodierknechtC Codierknecht

                        @ciddi89
                        Was ist denn, wenn Du in writeDatapoints(adptName) aus dem hier:

                        // list battery low powered
                        if (this.lowBatteryPoweredCount === 0) {
                        	// if no device is count, write the JSON List with default value
                        	this.batteryLowPowered = [{ Device: '--none--', Adapter: '', Battery: '' }];
                        }
                        //write JSON list
                        await this.setStateAsync(`devices.${dpSubFolder}lowBatteryList`, {
                        	val: JSON.stringify(this.batteryLowPowered),
                        	ack: true,
                        });
                        
                        

                        Das hier machst:

                        // list battery low powered
                        if (this.lowBatteryPoweredCount === 0) {
                        	// if no device is count, write the JSON List with default value
                        	this.batteryLowPowered = [{ Device: '--none--', Adapter: '', Battery: '' }];
                        } else {
                          //write JSON list
                          await this.setStateAsync(`devices.${dpSubFolder}lowBatteryList`, {
                          	val: JSON.stringify(this.batteryLowPowered),
                          	ack: true,
                          });
                        }
                        

                        Das "umgeht" zwar nur das eigentliche Problem, sollte aber helfen.

                        ? Offline
                        ? Offline
                        Ein ehemaliger Benutzer
                        schrieb am zuletzt editiert von Ein ehemaliger Benutzer
                        #21

                        @codierknecht naja was soll da umgehen werden? Das wird dann trotzdem genau so ausgeführt werden. Also das end Ergebnis wird gleich bleiben.

                        //Edit: sry nun erst richtig wach. Das Ergebnis wird bei deinem Vorschlag doch nicht gleich bleiben da setState bei 0 garnicht ausgeführt wird. Aber egal wie der Stand ist, er soll immer ausgeführt werden.

                        CodierknechtC 1 Antwort Letzte Antwort
                        0
                        • ? Ein ehemaliger Benutzer

                          @codierknecht naja was soll da umgehen werden? Das wird dann trotzdem genau so ausgeführt werden. Also das end Ergebnis wird gleich bleiben.

                          //Edit: sry nun erst richtig wach. Das Ergebnis wird bei deinem Vorschlag doch nicht gleich bleiben da setState bei 0 garnicht ausgeführt wird. Aber egal wie der Stand ist, er soll immer ausgeführt werden.

                          CodierknechtC Offline
                          CodierknechtC Offline
                          Codierknecht
                          Developer Most Active
                          schrieb am zuletzt editiert von
                          #22

                          @ciddi89 sagte in Skript löst "fälschlicherweise" aus:

                          Aber egal wie der Stand ist, er soll immer ausgeführt werden.

                          Stimmt auch wieder. War wohl auch noch nicht richtig wach :-(
                          Und wenn tatsächlich mal ein Gerät zu melden wäre, würde das ja auch immer wieder geschrieben.

                          "Any fool can write code that a computer can understand. Good programmers write code that humans can understand." (Martin Fowler, "Refactoring")

                          Proxmox 9.1.1 LXC|8 GB|Core i7-6700
                          HmIP|ZigBee|Tasmota|Unifi
                          Zabbix Certified Specialist
                          Konnte ich Dir helfen? Dann benutze bitte das Voting unten rechts im Beitrag

                          ? 1 Antwort Letzte Antwort
                          0
                          • CodierknechtC Codierknecht

                            @ciddi89 sagte in Skript löst "fälschlicherweise" aus:

                            Aber egal wie der Stand ist, er soll immer ausgeführt werden.

                            Stimmt auch wieder. War wohl auch noch nicht richtig wach :-(
                            Und wenn tatsächlich mal ein Gerät zu melden wäre, würde das ja auch immer wieder geschrieben.

                            ? Offline
                            ? Offline
                            Ein ehemaliger Benutzer
                            schrieb am zuletzt editiert von Ein ehemaliger Benutzer
                            #23

                            @codierknecht das was ich Adapter seitig machen kann ist den Wert zu vergleichen mit den Datenpunkt und dann wirklich nur bei Änderung schreiben lassen. Werde mal gucken wie andere devs das so machen.

                            1 Antwort Letzte Antwort
                            0
                            • ? Offline
                              ? Offline
                              Ein ehemaliger Benutzer
                              schrieb am zuletzt editiert von
                              #24

                              Soooo habe auch herausgefunden warum er das macht und konnte den Fehler Adapterseitig beseitigen.

                              Anstatt einfach nur setStateAsync muss man setStateChangedAsync nutzen. Dann beschreibt der Adapter den Datenpunkt nur wenn der Wert wirklich anders ist. Somit wieder was gelernt. :)

                              @David-G In der Github Version ist es bereits geändert. Ansonsten auf das nächste Release warten.

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


                              Support us

                              ioBroker
                              Community Adapters
                              Donate

                              675

                              Online

                              32.5k

                              Benutzer

                              81.6k

                              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