Skip to content
  • 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
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Skript LOWBAT

NEWS

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

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

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

Skript LOWBAT

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
201 Beiträge 44 Kommentatoren 51.6k Aufrufe 14 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.
  • D Offline
    D Offline
    dali3
    schrieb am zuletzt editiert von
    #108

    Text/Name habe ich nun anpassen können. Neustart hilft 🙂

    Nun noch weshalb "false"
    4746_x14.jpg

    Systeminfo:
    Iobroker Pro, Surface 3 (Mobil), Acer T272 (Wand), Raspberry Pi 3, NUC, Synology DS212j (BackUp), Google Home, Xiaomi Aqara (Sensoren, Fühler, Kamera, LED), Revo Superconnect, Philips Hue, IKEA Tradfri...

    1 Antwort Letzte Antwort
    0
    • T Offline
      T Offline
      tempestas
      schrieb am zuletzt editiert von
      #109

      Sehr schön.

      Das "Bestätigt: false" kannst du ignorieren.

      Ich habe das Skript nochmal angepasst, um das "Battery percent" rauszunehmen.

      Sobald du alle Magneten und sonstiges benannt hast und nochmal neugestartet hast, kannst du es ja ausprobieren

      ! ````
      ! createState('zählenLowbat.möglicheLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
      createState('zählenLowbat.anzahlLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT
      createState('zählenLowbat.textLOWBAT', " "); // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
      ! var minlevel = 87; // HIER LEGT DU DEINE SCHWELLE FEST. ICH HABE DIE 87% WILLKÜRLICH GEWÄHLT, denn damit sollte beim Test mindestens einmal "lowbat".rauskommen
      ! var cacheSelectorLOWBAT = $('channel[state.id=*.percent]'); // HIER HABE ICH NUN AUF DEIEN PROZENT WERT VERWIESEN
      ! function countLowbat(obj) {
      // Setzt die Zähler vor dem Durchlauf aller Elemente auf 0
      var moeglicheLOWBAT = 0;
      var textLOWBAT = [];
      var lowbattery = false; // NEU EINGEFÜGT
      ! if (obj) {
      log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat
      } else {
      log('Ausgelöst bei Timer');
      }
      ! cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT
      var value = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element)

        if(value < minlevel){lowbattery = true} else {lowbattery = false}         // NEU EINGEFÜGT. Ist der Ladestand kleiner als der Schwellwert? Wenn ja, setze die Variable lowbattery auf true
      
        var obj    = getObject(id);
        var name = getObject(id).common.name;
        var devicename = name.replace("Battery percent","");
        if (lowbattery=== true) {                                          // wenn Zustand der Variable "lowbattery" = true, dann wird die Anzahl der Geräte hochgezählt
           textLOWBAT.push(devicename);                           // Zu Array hinzufügen
        }                
        log("Geräte Nr. " + i + ": " + devicename + "meldet: " + lowbattery);
        ++moeglicheLOWBAT;                                                 // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
      

      });

      ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
      log("Text: " + textLOWBAT.join(', '));
      log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " + textLOWBAT.length);
      ! // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
      setState("zählenLowbat.textLOWBAT", textLOWBAT.join(',
      ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
      setState("zählenLowbat.anzahlLOWBAT", textLOWBAT.length); // Schreibt die aktuelle Anzahl der Geräte im System
      setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT); // Schreibt die aktuelle Anzahl der vorhandene Geräte
      }
      ! cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung . LOWBAT in allen Gewerken
      countLowbat(obj);
      });
      schedule("
      /60 * * * *", function () { //oder!! soll entweder ausgelöst werden alle 10 Minuten
      countLowbat();
      });
      ! // Bei Start:
      ! countLowbat();
      ! ````

      <size="85">ioBroker | 21 Adapter | Ubuntu Server | intel NUC | Homematic CCU2 | Hue | Osram Lightify| Sonos | 2x Instar Cam | Samsung Tab A 2016 im Holzrahmen| 3x Echo dot | 1x Echo | Neato Botvac D5</size>

      1 Antwort Letzte Antwort
      0
      • D Offline
        D Offline
        dali3
        schrieb am zuletzt editiert von
        #110

        perfekt! Herzlichen Dank! Funktioniert nun TOP!!

        Danke für deine tolle Unterstützung!!!

        Hier noch das passende Bild dazu:
        4746_x1.jpg

        Systeminfo:
        Iobroker Pro, Surface 3 (Mobil), Acer T272 (Wand), Raspberry Pi 3, NUC, Synology DS212j (BackUp), Google Home, Xiaomi Aqara (Sensoren, Fühler, Kamera, LED), Revo Superconnect, Philips Hue, IKEA Tradfri...

        1 Antwort Letzte Antwort
        0
        • T Offline
          T Offline
          tempestas
          schrieb am zuletzt editiert von
          #111

          Gern geschehen. Schön, dass es läuft

          <size="85">ioBroker | 21 Adapter | Ubuntu Server | intel NUC | Homematic CCU2 | Hue | Osram Lightify| Sonos | 2x Instar Cam | Samsung Tab A 2016 im Holzrahmen| 3x Echo dot | 1x Echo | Neato Botvac D5</size>

          1 Antwort Letzte Antwort
          0
          • F Offline
            F Offline
            firephaser
            schrieb am zuletzt editiert von
            #112

            Hallo zusammen,

            ich habe die Scripte Lowbat, Fenster und offene Konfiguration aus diesem Threat erfolgreich bei mir am laufen, einzig das Script Lichter will nicht.

            createState('zählen_Lichter.anzahlLichter', 0);                     // wenn benötigt: Anzahl der vorhandenen Lichter
            createState('zählen_Lichter.anzahlLichterAn', 0);                   // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
            
            var cacheSelector = $('channel[state.id=*.STATE](functions=funcLight)');
            createState('zählen_Lichter.anzahlLichter', 0);                     // wenn benötigt: Anzahl der vorhandenen Lichter
            createState('zählen_Lichter.anzahlLichterAn', 0);                   // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
            createState('zählen_Lichter.textLichterAn', " ");                   // Text der Lichter, die an sind als Variable unter Javascript.0 anlegen
            
            var cacheSelectorState  = $('channel[state.id=*.STATE](functions=funcLight)');
            
            function countLamps(obj) {
                 // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Licht auf 0
                var anzahlLichterAn = 0;
                var anzahlLichter = 0;
                var textLichterAn = [];
            
               log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);   // Info im Log, welcher Zustand sich geändert hat
            
               cacheSelectorState.each(function (id, i) {                       // Schleife für jedes gefundenen Element *.STATE im Gewerk Licht
                    var status = getState(id).val;                              // Zustand *.STATE abfragen (jedes Element)
                    var obj    = getObject(id);
                    if (status === true) {                                      // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                         textLichterAn.push(obj.common.name);                   // Zu Array hinzufügen
                    }                
                    log("Licht Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                    ++anzahlLichter;                                            // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                }); 
            
                // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                    log("Text: " + textLichterAn);
                    log("Anzahl Lichter: " + anzahlLichter + " # davon Lichter an: " + anzahlLichterAn);
            
                // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
               setState("zählen_Lichter.textLichterAn", textLichterAn.join(',
            '));    // Schreibt die aktuelle Namen der eingeschalteten Lichter
               setState("zählen_Lichter.anzahlLichterAn", textLichterAn.length);        // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
               setState("zählen_Lichter.anzahlLichter", anzahlLichter);                 // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
            }
            
            cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Fenster
               countLamps(obj);
            });
            

            Das Script zeigt bei mir keine Fehler an und die Datenpunkte unter Objekte werden erzeugt.

            Unter "Aufzählungen" kann ich in enum.functions den Punkt "Licht" mit 21 Geräten sehen. Am Anfang konnte ich nur den Punkt $(funcLight) sehen, aber der Hinweis mit dem mehrmaligen Umbenennen des Gewerkes in der CCU2 hat den Namen in "Licht" geändert.

            Starte ich das Script nun fällt mir als erstes auf, das kein Scheduler gestartet wird, ist das im Script Lichter anders gegenüber dem z.B. Fenster Script! Ich dacht das dieses in einer Schleife läuft und auf Veränderungen reagiert.

            Schalte ich nun Lampen an, die sich im Gewerk Licht befinden, ändert sich beim Script "Lichter" und den Datenpunkten nichts. Auch ein manuelles Ausführen des Scriptes füllt die Datenpunkte nicht.

            Ich habe auch schon verschiedene Gewerke z.B. CCULicht ausprobiert, leider mit dem selben Ergebnis.

            Hat jemand eine Idee

            Vielen Dank und Gruß

            Micha
            4781_io1.png

            iObroker 3

            1 Antwort Letzte Antwort
            0
            • P Offline
              P Offline
              pix
              schrieb am zuletzt editiert von
              #113

              Hallo Micha,

              schnell per tapatalk: ändere

              var cacheSelectorState= $('channel[state.id=*.STATE](functions=funcLight)');
              
              

              in

              var cacheSelectorState  = $('channel[state.id=*.STATE](functions=Licht)');
              

              Und wenn ich dein Skript hier vollständig gesehen hab, dann brauchst du

              var cacheSelector // ohne State 
              
              

              gar nicht.

              Pix

              ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

              1 Antwort Letzte Antwort
              0
              • F Offline
                F Offline
                firephaser
                schrieb am zuletzt editiert von
                #114

                Habe ich geändert, doch leider auch keine Änderung

                createState('zählen_Lichter.anzahlLichter', 0);                     // wenn benötigt: Anzahl der vorhandenen Lichter
                createState('zählen_Lichter.anzahlLichterAn', 0);                   // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                
                createState('zählen_Lichter.anzahlLichter', 0);                     // wenn benötigt: Anzahl der vorhandenen Lichter
                createState('zählen_Lichter.anzahlLichterAn', 0);                   // Anzahl der Lichter, die an sind als Variable unter Javascript.0 anlegen
                createState('zählen_Lichter.textLichterAn', " ");                   // Text der Lichter, die an sind als Variable unter Javascript.0 anlegen
                
                var cacheSelectorState  = $('channel[state.id=*.STATE](functions=Licht)');
                
                function countLamps(obj) {
                     // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Licht auf 0
                    var anzahlLichterAn = 0;
                    var anzahlLichter = 0;
                    var textLichterAn = [];
                
                   log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);   // Info im Log, welcher Zustand sich geändert hat
                
                   cacheSelectorState.each(function (id, i) {                       // Schleife für jedes gefundenen Element *.STATE im Gewerk Licht
                        var status = getState(id).val;                              // Zustand *.STATE abfragen (jedes Element)
                        var obj    = getObject(id);
                        if (status === true) {                                      // wenn Zustand = true, dann wird die ANzahl der Lichter hochgezählt
                             textLichterAn.push(obj.common.name);                   // Zu Array hinzufügen
                        }                
                        log("Licht Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                        ++anzahlLichter;                                            // Zählt die Anzahl der vorhandenen Lichter unabhängig vom Status
                    }); 
                
                    // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                        log("Text: " + textLichterAn);
                        log("Anzahl Lichter: " + anzahlLichter + " # davon Lichter an: " + anzahlLichterAn);
                
                    // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                   setState("zählen_Lichter.textLichterAn", textLichterAn.join(',
                '));    // Schreibt die aktuelle Namen der eingeschalteten Lichter
                   setState("zählen_Lichter.anzahlLichterAn", textLichterAn.length);        // Schreibt die aktuelle Anzahl der eingeschalteten Lichter
                   setState("zählen_Lichter.anzahlLichter", anzahlLichter);                 // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Licht
                }
                
                cacheSelectorState.on(function(obj) {    // bei Zustandänderung *. STATE im Gewerk Fenster
                   countLamps(obj);
                });
                
                

                Oder ist noch etwas im Script falsch?

                iObroker 3

                1 Antwort Letzte Antwort
                0
                • W Offline
                  W Offline
                  Wuast94
                  schrieb am zuletzt editiert von
                  #115

                  ich bin da gerade zu blond für 😄 was muss ich tun um das zum laufen zu bekommen ? habe iobroker heute frisch installiert und meine ccu2 verbunden.

                  1 Antwort Letzte Antwort
                  0
                  • P Offline
                    P Offline
                    pix
                    schrieb am zuletzt editiert von
                    #116

                    Hallo,

                    willkommen bei ioBroker.

                    Bitte http://www.iobroker.net/docu/?page_id=6818&lang=de installieren und Skript dort pasten.

                    Wenn neu, dann Doku lesen/überfliegen:

                    http://www.iobroker.net/docu

                    Oder mal nach "javascript Adapter installieren" suchen

                    Gruß

                    Pix

                    ioBroker auf Ubuntu in Proxmox (früher Mac mini (bis OS X 10.12.6 Sierra), VIS via iOS; angeschlossen: Homematic CCU2, Homepilot 1, ConBee II, einige Wemos, Sonos, Unifi CK+Protect, Homekit, Homebridge; KEIN blockly! Github-Profil

                    1 Antwort Letzte Antwort
                    0
                    • M Offline
                      M Offline
                      marphDE
                      schrieb am zuletzt editiert von
                      #117

                      Hallo,

                      danke erstmal für das Script.

                      Bei mir funktioniert das zählen der "möglichenLOWBAT" leider nicht.

                      Kann mir bitte jemand helfen den Fehler zu finden.

                      4060_bildschirmfoto_2018-02-09_um_23.42.04.png

                      ! ! createState('zählenLowbat.moeglicheLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT createState('zählenLowbat.anzahlLOWBAT', 0); // wenn benötigt: Anzahl der vorhandenen LOWBAT createState('zählenLowbat.textLOWBAT', " "); // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen ! var cacheSelectorLOWBAT = $('channel[state.id=*.LOWBAT]'); ! function countLowbat(obj) { // Setzt die Zähler vor dem Durchlauf aller Elemente *.LOWBAT auf 0 var moeglicheLOWBAT = 0; var anzahlLOWBAT = 0; var textLOWBAT = []; ! if (obj) { log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat } else { log('Ausgelöst bei Timer'); } ! cacheSelectorLOWBAT.each(function (id, i) { // Schleife für jedes gefundenen Element *.LOWBAT var status = getState(id).val; // Zustand *.LOWBAT abfragen (jedes Element) var obj = getObject(id); if (status === true) { // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt textLOWBAT.push(obj.common.name); // Zu Array hinzufügen } log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status); ++anzahlLOWBAT; // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status }); ! // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben log("Text: " + textLOWBAT); log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " + anzahlLOWBAT); ! // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS) setState("zählenLowbat.textLOWBAT", textLOWBAT.join(', ')); // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung setState("zählenLowbat.anzahlLOWBAT", textLOWBAT.length); // Schreibt die aktuelle Anzahl der Geräte im System setState("zählenLowbat.moeglicheLOWBAT", moeglicheLOWBAT); // Schreibt die aktuelle Anzahl der vorhandene Geräte } ! cacheSelectorLOWBAT.on(function(obj) { // bei Zustandänderung *. LOWBAT in allen Gewerken countLowbat(obj); }); schedule("*/10 * * * *", function () { //oder!! soll entweder ausgelöst werden alle 10 Minuten log("===>Will be triggered every 60 minutes!"); countLowbat(); }); !

                      1 Antwort Letzte Antwort
                      0
                      • paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von
                        #118

                        Siehe http://forum.iobroker.net/viewtopic.php?f=21&t=869&start=60#p76769.

                        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
                        • M Offline
                          M Offline
                          marphDE
                          schrieb am zuletzt editiert von
                          #119

                          vielen Dank, hat super funktioniert. 😄

                          1 Antwort Letzte Antwort
                          0
                          • S Offline
                            S Offline
                            Superdad
                            schrieb am zuletzt editiert von
                            #120

                            Hallo,

                            habe mir mal das LowBat-Script von hier zusammen geklickt (geklaut).

                            //  http://forum.iobroker.net/viewtopic.php?f=21&t=869&sid=f9ba5657489ff431a1990884f90779c1#p6564
                            //  https://forum.iobroker.net/viewtopic.php?f=21&t=869&start=60
                            //  https://forum.iobroker.net/viewtopic.php?f=21&t=869&start=100
                            
                            createState('zählenLowbat.möglicheLOWBAT', 0);                                  // wenn benötigt: Anzahl der vorhandenen LOWBAT
                            createState('zählenLowbat.anzahlLOWBAT', 0);                                    // wenn benötigt: Anzahl der vorhandenen LOWBAT
                            createState('zählenLowbat.textLOWBAT', " ");                                    // Anzahl LOWBAT, die an sind als Variable unter Javascript.0 anlegen
                            
                            var minlevel = 87;                                                              // HIER LEGT DU DEINE SCHWELLE FEST. ICH HABE DIE 87% WILLKÜRLICH GEWÄHLT, denn damit sollte beim Test mindestens einmal "lowbat".rauskommen            
                            
                            var cacheSelectorLOWBAT  = $('channel[state.id=*.percent]');                    // HIER HABE ICH NUN AUF DEIEN PROZENT WERT VERWIESEN
                            var cacheSelectorLOW_BAT  = $('channel[state.id=*.LOW_BAT]');                   // für Homematic IP, dort LOWBAT in LOW_BAT umbenannt
                            
                            function countLowbat(obj) {
                               // Setzt die Zähler vor dem Durchlauf aller Elemente auf 0
                               var moeglicheLOWBAT = 0;
                               var textLOWBAT      = [];
                               var lowbattery = false;                                                      // NEU EINGEFÜGT
                            
                               if (obj) {
                                  log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val);            // Info im Log, welcher Zustand sich geändert hat
                               } else {
                                  log('Ausgelöst bei Timer'); 
                               } 
                            
                               cacheSelectorLOWBAT.each(function (id, i) {                                  // Schleife für jedes gefundenen Element *.LOWBAT
                                  var value = getState(id).val;                                             // Zustand *.LOWBAT abfragen (jedes Element)
                            
                                  if(value < minlevel){lowbattery = true} else {lowbattery = false}         // NEU EINGEFÜGT. Ist der Ladestand kleiner als der Schwellwert? Wenn ja, setze die Variable lowbattery auf true
                            
                                  var obj    = getObject(id);
                                  var name = getObject(id).common.name;
                                  var devicename = name.replace("Battery percent","");
                                  if (lowbattery=== true) {                                                 // wenn Zustand der Variable "lowbattery" = true, dann wird die Anzahl der Geräte hochgezählt
                                     textLOWBAT.push(devicename);                                           // Zu Array hinzufügen
                                  }                
                                  log("Geräte Nr. " + i + ": " + devicename + " " + "meldet: " + lowbattery);
                                  ++moeglicheLOWBAT;                                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                               }); 
                            
                               cacheSelectorLOWBAT.each(function (id, i) {                                  // Schleife für jedes gefundenen Element *.LOWBAT
                                  var status = getState(id).val;                                            // Zustand *.LOWBAT abfragen (jedes Element)
                                  var obj    = getObject(id);
                                  if (status === true) {                                                    // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                     textLOWBAT.push(obj.common.name);                                      // Zu Array hinzufügen
                                  }                
                                  log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                  ++moeglicheLOWBAT;                                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                               }); 
                            
                               cacheSelectorLOW_BAT.each(function (id, i) {                                 // Schleife für jedes gefundenen Element *.LOW_BAT, Homematic IP
                                  var status = getState(id).val;                                            // Zustand *.LOW_BAT abfragen (jedes Element)
                                  var obj    = getObject(id);
                                  if (status === true) {                                                    // wenn Zustand = true, dann wird die Anzahl der Geräte hochgezählt
                                     textLOWBAT.push(obj.common.name);                                      // Zu Array hinzufügen
                                  }                
                                  log("Geräte Nr. " + i + ": " + getObject(id).common.name + ": " + status);
                                  ++moeglicheLOWBAT;                                                        // Zählt die Anzahl der vorhandenen Geräte unabhängig vom Status
                               }); 
                            
                               // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon LOWBAT zutreffend) ausgegeben
                               log("Text: " + textLOWBAT.join(', '));
                               log("Anzahl Geräte: " + moeglicheLOWBAT + " # davon LOWBAT erkannt: " +  textLOWBAT.length);
                            
                               // die ermittelten Werte werden als javascript.0\. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                               setState("zählenLowbat.textLOWBAT",     textLOWBAT.join(',
                            '));           // Schreibt die aktuelle Namen der Geräte mit LOWBAT Meldung
                               setState("zählenLowbat.anzahlLOWBAT",   textLOWBAT.length);                  // Schreibt die aktuelle Anzahl der Geräte im System
                               setState("zählenLowbat.möglicheLOWBAT", moeglicheLOWBAT);                    // Schreibt die aktuelle Anzahl der vorhandene Geräte 
                            }
                            
                            cacheSelectorLOWBAT.on(function(obj) {                                          // bei Zustandänderung *. LOWBAT in allen Gewerken
                               countLowbat(obj);
                            });
                            
                            cacheSelectorLOW_BAT.on(function(obj) {                                         // bei Zustandänderung *. LOW_BAT in allen Gewerken
                               countLowbat(obj);
                            });
                            
                            //schedule("*/60 * * * *", function () {                                        //oder!! soll entweder ausgelöst werden alle 10 Minuten
                            //   countLowbat();
                            //});
                            
                            // Bei Start:
                            
                            countLowbat();
                            

                            Das Problem was ich habe, dass nicht alle Geräte erkannt werden.

                            Im Log werden 19 erkannte Geräte angezeigt.

                            Ich habe aber 39.

                            9:47:18.631	[info]	javascript.0 Stop script script.js.Haus.Low_Batterie_neu
                            19:47:18.791	[info]	javascript.0 Start javascript script.js.Haus.Low_Batterie_neu
                            19:47:18.791	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Ausgelöst bei Timer
                            19:47:18.791	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 0: Kueche Temp meldet: true
                            19:47:18.791	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 1: Waschküche Temp meldet: true
                            19:47:18.791	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 2: Lichtschalter DB meldet: true
                            19:47:18.791	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 3: Fensterkontakt Kueche meldet: true
                            19:47:18.791	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 4: DB1 meldet: false
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 5: DB2 meldet: false
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 6: DB3 meldet: false
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 7: Cube meldet: true
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 0: Battery percent Kueche Temp: 78.5
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 1: Battery percent Waschküche Temp: 80.5
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 2: Battery percent Lichtschalter DB: 85.2
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 3: Battery percent Fensterkontakt Kueche: 85.5
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 4: Battery percent DB1: 91.5
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 5: Battery percent DB2: 87.5
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 6: Battery percent DB3: 87.5
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 7: Battery percent Cube: 82.5
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 0: Thermostat Bad:0.LOW_BAT: false
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 1: Thermostat SZ:0.LOW_BAT: false
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Geräte Nr. 2: Thermostat WZ:0.LOW_BAT: false
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Text: Kueche Temp, Waschküche Temp, Lichtschalter DB, Fensterkontakt Kueche, Cube
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: Anzahl Geräte: 19 # davon LOWBAT erkannt: 5
                            19:47:18.792	[info]	javascript.0 script.js.Haus.Low_Batterie_neu: registered 11 subscriptions and 0 schedules
                            

                            Nur leider weiss ich nicht woran das liegen könnte.

                            Kann mir da jemand auf die Sprünge helfen?

                            CCU3

                            iOBroker auf IntelNUC Proxmox

                            1 Antwort Letzte Antwort
                            0
                            • L Online
                              L Online
                              Linedancer
                              schrieb am zuletzt editiert von
                              #121

                              Hallo Gemeinde,

                              Ich verwende das hier vorgestellte Script zum erkennen des Fenster Status von HM Fensterkontakten seit Monaten problemlos.

                              Jetzt ist ein Wemos D1 mini mit Easy ESP dazu gekommen, der einen Reed Fensterkontakt liest. Der Status wird korrekt per MQTT Adapter empfangen.

                              Leider bekomme ich den MQTT Datenpunkt nicht mit dem Fenster Script erfasst.

                              Ich habe den Datenpunkt in das entsprechende Gewerk eingetragen und den type auf "state" geändert. Leider wird der Datenpunkt nicht von dem Fenster Script erkannt.

                              Wo kann ich hier den Hebel ansetzen?

                              –

                              Ciao, Gerhard

                              1 Antwort Letzte Antwort
                              0
                              • paul53P Offline
                                paul53P Offline
                                paul53
                                schrieb am zuletzt editiert von
                                #122

                                @Linedancer:

                                Wo kann ich hier den Hebel ansetzen? `
                                Teste in einem separaten Skript, ob der verwendete Selektor passt, z.B.

                                const mqttFenster = $('mqtt.0.*(functions=fenster)');
                                
                                mqttFenster.each(function(id, i) {
                                   log(id);
                                });
                                

                                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
                                • L Online
                                  L Online
                                  Linedancer
                                  schrieb am zuletzt editiert von
                                  #123

                                  Hallo Paul53,

                                  dein Testscript spuckt den richtigen Datenpunkt im log aus. Das ist ja schon mal was.

                                  –

                                  Ciao, Gerhard

                                  1 Antwort Letzte Antwort
                                  0
                                  • paul53P Offline
                                    paul53P Offline
                                    paul53
                                    schrieb am zuletzt editiert von
                                    #124

                                    @Superdad:

                                    Das Problem was ich habe, dass nicht alle Geräte erkannt werden.

                                    …

                                    Kann mir da jemand auf die Sprünge helfen? `

                                    var cacheSelectorLOWBAT  = $('channel[state.id=*.percent]');                    // HIER HABE ICH NUN AUF DEIEN PROZENT WERT VERWIESEN
                                    var cacheSelectorLOW_BAT  = $('channel[state.id=*.LOW_BAT]');                   // für Homematic IP, dort LOWBAT in LOW_BAT umbenannt
                                    
                                    

                                    Es fehlt sicherlich ein dritter Selektor mit 'channel[state.id=*.LOWBAT]', denn in der Funktion wird 2 mal der gleiche Schleifen-Selektor verwendet: Einmal als Prozentwert und einmal als Logikwert.

                                    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
                                    • L Online
                                      L Online
                                      Linedancer
                                      schrieb am zuletzt editiert von
                                      #125

                                      Hallo Paul53,

                                      so ganz habe ich deine Antwort nicht verstanden.

                                      Hier mal die Einstellungen meines Datenpunktes:

                                      {
                                        "common": {
                                          "name": "/UG_Heizraum_Temperaturen/status",
                                          "write": true,
                                          "read": true,
                                          "role": "variable",
                                          "desc": "mqtt server variable",
                                          "type": "string"
                                        },
                                        "native": {
                                          "topic": "/UG_Heizraum_Temperaturen/status"
                                        },
                                        "type": "state",
                                        "from": "system.adapter.mqtt.0",
                                        "ts": 1528819145714,
                                        "_id": "mqtt.0.UG_Heizraum_Temperaturen.status",
                                        "acl": {
                                          "object": 1636,
                                          "state": 1636,
                                          "owner": "system.user.admin",
                                          "ownerGroup": "system.group.administrator"
                                        }
                                      }
                                      

                                      Ich hab den Datenpunkt so weit wie möglich an die HM Drehgriff Sensoren angepasst, tut aber nicht.

                                      –

                                      Ciao, Gerhard

                                      1 Antwort Letzte Antwort
                                      0
                                      • paul53P Offline
                                        paul53P Offline
                                        paul53
                                        schrieb am zuletzt editiert von
                                        #126

                                        @Linedancer:

                                        so ganz habe ich deine Antwort nicht verstanden. `
                                        Poste mal Dein Skript.

                                        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
                                        • L Online
                                          L Online
                                          Linedancer
                                          schrieb am zuletzt editiert von
                                          #127

                                          Hier wäre mein Script.

                                          Ich habe nur den Gewerk Namen editiert.

                                          ! ````
                                          /* System Zahl Fenster
                                          ! zählt die Fenster in allen Räumen und meldet die offenen Fenster namentlich
                                          Daten kommen vom Gewerk 'Fenster'
                                          ! erstellt: 17.06.2015 nach diesem Vorbild: http://forum.iobroker.net/viewtopic.php?f=21&t=869&sid=f9ba5657489ff431a1990884f90779c1#p6564
                                          05.08.2015 STATE aus der Ausgabe entfernt nach Idee von stephan61 http://forum.iobroker.org/viewtopic.php?f=21&t=473&start=20#p9267
                                          02.12.2015 Fehler beseitigt bei Anzahl Fenster, wenn offen (Unterscheidung RHS und TFK)
                                          Überprüfung des Zustandes (function fensterstatus) und Übergabe an Text
                                          25.01.2016 Fenster Nummer in Log korrigiert (+1)
                                          02.03.2016 Ansage für TTS aufbereitet
                                          02.07.2016 Regulärer Ausdruck (gierig) bei Aufbereitung für Ansage
                                          */
                                          ! function fensterstatus(zustand) {
                                          var meldung;
                                          switch (zustand) {
                                          case 1:
                                          meldung = 'RHS gekippt';
                                          break;
                                          case 2:
                                          meldung = 'RHS offen';
                                          break;
                                          case true:
                                          meldung = 'TFK offen';
                                          break;
                                          default:
                                          meldung = 'geschlossen';
                                          break;
                                          }
                                          return(meldung);
                                          }
                                          ! createState('zählen_Fenster_Keller.anzahlFenster', { // wenn benötigt: Anzahl der vorhandenen Fenster
                                          type: 'number',
                                          min: 0,
                                          def: 0,
                                          role: 'value'
                                          });
                                          createState('zählen_Fenster_Keller.anzahlFensterauf', { // Anzahl der Fenster, die auf sind als Variable unter Javascript.0 anlegen
                                          type: 'number',
                                          min: 0,
                                          def: 0,
                                          role: 'value'
                                          });
                                          createState('zählen_Fenster_Keller.textFensterauf', { // Anzahl der offenen Fenster und deren Namen als Variable unter Javascript.0 anlegen
                                          type: 'string',
                                          def: ' ',
                                          role: 'value'
                                          });
                                          ! var cacheSelectorState = $('channelstate.id=*.STATE');
                                          ! function countFenster(obj) {
                                          // Setzt die Zähler vor dem Durchlauf aller Elemente *.STATE im Gewerk Fenster auf 0
                                          var anzahlFenster = 0;
                                          var anzahlFensterauf = 0;
                                          var textFensterauf = [];
                                          ! log('Auslösender Aktor: ' + obj.id + ': ' + obj.newState.val); // Info im Log, welcher Zustand sich geändert hat

                                          cacheSelectorState.each(function (id, i) {                                  // Schleife für jedes gefundenen Element *.STATE im Gewerk Fenster
                                              var status = getState(id).val;                                          // Zustand *.STATE abfragen (jedes Element)
                                              var obj    = getObject(id);
                                              var name = getObject(id).common.name;
                                              var devicename = name.substring(0, name.indexOf(".STATE"));             //.state aus Text entfernen
                                              if (status /*TFK*/ || status === 1 || status === 2 /*RHS*/) {  // wenn Zustand offen, dann wird die Anzahl der Fenster hochgezählt
                                                   ++anzahlFensterauf;
                                                   textFensterauf.push(devicename + ' (' + fensterstatus(status) + ')');  // Name und Zustand zum Array hinzufügen
                                              }                
                                              log('Fenster_Keller #' + (i+1) + ': ' + devicename + ' ' + fensterstatus(status)/* + ' (' + status + ' / ' + typeof status + ')'*/);
                                              ++anzahlFenster;                                                        // Zählt die Anzahl der vorhandenen Fenster unabhängig vom Status
                                          }); 
                                          
                                          // Schleife ist durchlaufen. Im Log wird der aktuelle Status (Anzahl, davon an) ausgegeben
                                              log("Text: " + textFensterauf);
                                              log("Anzahl Fenster: " + anzahlFenster + " - davon Fenster auf: " +  anzahlFensterauf);
                                          

                                          ! // die ermittelten Werte werden als javascript.0. Variable in ioBroker gespeichert (z.B. für die Verarbeitung in VIS)
                                          setState("zählen_Fenster_Keller.textFensterauf", textFensterauf.join(',
                                          ')); // Schreibt die aktuelle Namen der offenen Fenster
                                          setState("zählen_Fenster_Keller.anzahlFensterauf", textFensterauf.length); // Schreibt die aktuelle Anzahl der offenen Fenster
                                          setState("zählen_Fenster_Keller.anzahlFenster", anzahlFenster); // Schreibt die aktuelle Anzahl der vorhandene Elemente im Gewerk Fenster
                                          }
                                          ! cacheSelectorState.on(function(obj) { // bei Zustandänderung *. STATE im Gewerk Fenster
                                          countFenster(obj);
                                          });
                                          ! // Variable für Ansage aufbereiten
                                          createState('zählen_Fenster_Keller.textFensteraufAnsage', {
                                          type: 'string',
                                          def: ' ',
                                          role: 'value'
                                          });
                                          // Anzahl der Fenster, die auf sind, für Ansage aufbereitet
                                          var idQuelle = 'javascript.0.zählen_Fenster_Keller.textFensterauf',
                                          idAnsage = 'javascript.0.zählen_Fenster_Keller.textFensteraufAnsage';
                                          ! on(idQuelle, function (obj) {
                                          var text = obj.state.val;
                                          text = text.replace(/RHS/g, 'Drehgriff');
                                          text = text.replace(/TFK/g, 'Reedkontakt');
                                          text = (text.length > 1) ? 'Geöffnete Fenster: ' + text : 'Alle Fenster im Keller sind geschlossen';
                                          setState(idAnsage, text);
                                          });

                                          –

                                          Ciao, Gerhard

                                          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

                                          331

                                          Online

                                          32.4k

                                          Benutzer

                                          81.4k

                                          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
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe