Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
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

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    17
    1
    603

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    5.6k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

Skript löst "fälschlicherweise" aus

Scheduled Pinned Locked Moved Blockly
24 Posts 4 Posters 572 Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • 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
    wrote on last edited by
    #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 Replies Last reply
    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
      A Former User
      wrote on last edited by
      #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 Reply Last reply
      0
      • ? A Former User

        @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
        wrote on last edited by
        #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 Reply Last reply
        0
        • paul53P paul53

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

          ? Offline
          ? Offline
          A Former User
          wrote on last edited by
          #17

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

          CodierknechtC 1 Reply Last reply
          0
          • David G.D Online
            David G.D Online
            David G.
            wrote on last edited by
            #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 Reply Last reply
            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
              wrote on last edited by
              #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 Reply Last reply
              0
              • ? A Former User

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

                CodierknechtC Offline
                CodierknechtC Offline
                Codierknecht
                Developer Most Active
                wrote on last edited by 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 Reply Last reply
                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
                  A Former User
                  wrote on last edited by A Former User
                  #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 Reply Last reply
                  0
                  • ? A Former User

                    @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
                    wrote on last edited by
                    #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 Reply Last reply
                    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
                      A Former User
                      wrote on last edited by A Former User
                      #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 Reply Last reply
                      0
                      • ? Offline
                        ? Offline
                        A Former User
                        wrote on last edited by
                        #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 Reply Last reply
                        1
                        Reply
                        • Reply as topic
                        Log in to reply
                        • Oldest to Newest
                        • Newest to Oldest
                        • Most Votes


                        Support us

                        ioBroker
                        Community Adapters
                        Donate

                        623

                        Online

                        32.7k

                        Users

                        82.6k

                        Topics

                        1.3m

                        Posts
                        Community
                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                        ioBroker Community 2014-2025
                        logo
                        • Login

                        • Don't have an account? Register

                        • Login or register to search.
                        • First post
                          Last post
                        0
                        • Home
                        • Recent
                        • Tags
                        • Unread 0
                        • Categories
                        • Unreplied
                        • Popular
                        • GitHub
                        • Docu
                        • Hilfe