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. [Vorlage] Generische Batteriestandsüberwachung + Vis-ausgabe

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    18
    1
    677

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

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

[Vorlage] Generische Batteriestandsüberwachung + Vis-ausgabe

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascripttemplatemonitoring
581 Beiträge 81 Kommentatoren 137.6k Aufrufe 84 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.
  • T Offline
    T Offline
    Tobi81
    schrieb am zuletzt editiert von
    #512

    Ich habe JeeLink Sensoren, die den Zustand LowBatt 0 oder 1 liefern.

    Ich habe bisher nur die Funktionen BatterieSpannung_24 und BatterieSpannung_30.

    Brauche ich nun eine neue Funktion BatterieSpannung_1 oder wie gehe ich hier am besten vor um diesen Fall von dem Script zu berücksichtigen?

    Vielen Dank :)

    P 1 Antwort Letzte Antwort
    0
    • T Tobi81

      Ich habe JeeLink Sensoren, die den Zustand LowBatt 0 oder 1 liefern.

      Ich habe bisher nur die Funktionen BatterieSpannung_24 und BatterieSpannung_30.

      Brauche ich nun eine neue Funktion BatterieSpannung_1 oder wie gehe ich hier am besten vor um diesen Fall von dem Script zu berücksichtigen?

      Vielen Dank :)

      P Offline
      P Offline
      Pittini
      Developer
      schrieb am zuletzt editiert von
      #513

      @tobi81 BatterieSpannung_1 würde heißen in dem Gerät is ne Batterie mit 0,1 Volt. Haste so ein Gerät/Batterie? Nein. Womit die Frage geklärt wäre.
      Zum Thema 0 und 1, das ist neu und wird so vom Skript nicht erkannt, bei lowbat wird ein true oder false erwartet, also am besten nen Alias machen der die 0/1 zu true/false wandelt, dann wird das vom Skript auch erkannt. Die BatterieSpannung_xx ist IMMER die tatsächliche Spannung, egal ob da dann % oder lowbat oder was auch immer kommt.

      T Dominik F.D 2 Antworten Letzte Antwort
      0
      • P Pittini

        @tobi81 BatterieSpannung_1 würde heißen in dem Gerät is ne Batterie mit 0,1 Volt. Haste so ein Gerät/Batterie? Nein. Womit die Frage geklärt wäre.
        Zum Thema 0 und 1, das ist neu und wird so vom Skript nicht erkannt, bei lowbat wird ein true oder false erwartet, also am besten nen Alias machen der die 0/1 zu true/false wandelt, dann wird das vom Skript auch erkannt. Die BatterieSpannung_xx ist IMMER die tatsächliche Spannung, egal ob da dann % oder lowbat oder was auch immer kommt.

        T Offline
        T Offline
        Tobi81
        schrieb am zuletzt editiert von Tobi81
        #514

        @pittini Vielen Dank für die Erklärung.
        Ich habe noch nie einen Alias Datenpunkt erstellt. Geht das über den Alias-Adapter?
        Danach erstellt man die neuen Datenpunkte unter Alias.0. oder? Wie sage ich dann deinem Script das er diese Datenpunkte überwachen soll? Denen muss ich ja eine Funktion zuweisen, oder?

        Dominik F.D 1 Antwort Letzte Antwort
        0
        • T Tobi81

          @pittini Vielen Dank für die Erklärung.
          Ich habe noch nie einen Alias Datenpunkt erstellt. Geht das über den Alias-Adapter?
          Danach erstellt man die neuen Datenpunkte unter Alias.0. oder? Wie sage ich dann deinem Script das er diese Datenpunkte überwachen soll? Denen muss ich ja eine Funktion zuweisen, oder?

          Dominik F.D Offline
          Dominik F.D Offline
          Dominik F.
          schrieb am zuletzt editiert von
          #515

          @tobi81

          Nimm den Alias Manager, damit geht das sehr einfach. Es lohnt sich übrigens alle Datenpunkte, die du irgendwie brauchst, also nicht nur für dieses Skript, als Alias zu erstellen. Somit brauchst du, wenn du mal etwas austauscht, nur die Alias ändern, also die Datenpunkte im Alias nur neu zuweisen, und alles funktioniert weiterhin.

          Wenn du das erstellst hast, folgst du einfach den Anweisungen von Pittini in seiner Erklärung.

          1 Antwort Letzte Antwort
          0
          • P Pittini

            @tobi81 BatterieSpannung_1 würde heißen in dem Gerät is ne Batterie mit 0,1 Volt. Haste so ein Gerät/Batterie? Nein. Womit die Frage geklärt wäre.
            Zum Thema 0 und 1, das ist neu und wird so vom Skript nicht erkannt, bei lowbat wird ein true oder false erwartet, also am besten nen Alias machen der die 0/1 zu true/false wandelt, dann wird das vom Skript auch erkannt. Die BatterieSpannung_xx ist IMMER die tatsächliche Spannung, egal ob da dann % oder lowbat oder was auch immer kommt.

            Dominik F.D Offline
            Dominik F.D Offline
            Dominik F.
            schrieb am zuletzt editiert von
            #516

            @pittini

            Ich bekomme folgenden Log von dem Skript:

            avascript.0
            2022-02-08 18:50:48.543	info	script.js.common.Auswertung_Batterien: Reaching Meldung(), msg=Batteriestand (2.29 V) unter Limit (2.32 V) im EG Diele bei Gerät EG_Diele Heizkörper
            

            Problem an der Sache ist, der Batteriestand ist 2,4V, das wird auch in der Tabelle richtig erkannt:

            Unbenannt.PNG

            Hast du eine Idee was das Problem sein könnte?

            P 1 Antwort Letzte Antwort
            0
            • T Offline
              T Offline
              Tobi81
              schrieb am zuletzt editiert von
              #517

              Ich denke ich habe den Alias Adapter erfolgreich eingerichtet und ein Testdevice sieht jetzt so aus:

              Bildschirmfoto 2022-02-08 um 20.39.08.png

              Ich habe LowBatt nach lowbat umbenannt und die Funktion BatterieSpannung_30 hinzugefügt. Wenn ich jetzt das Script von Pittini neustarte bekomme ich folgende Fehlermeldungen:

              2022-02-08 20:45:41.094 - warn: javascript.0 (18309) getState "alias.0.TEST.lowBatt" not found (3)
              2022-02-08 20:45:41.095 - warn: javascript.0 (18309) at Init (script.js.common.BatterienÜberwachung:160:31)
              2022-02-08 20:45:41.095 - warn: javascript.0 (18309) at main (script.js.common.BatterienÜberwachung:261:5)
              2022-02-08 20:45:41.096 - warn: javascript.0 (18309) at Object. (script.js.common.BatterienÜberwachung:126:13)
              2022-02-08 20:45:41.096 - warn: javascript.0 (18309) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1988:38)
              2022-02-08 20:45:41.096 - warn: javascript.0 (18309) at processImmediate (internal/timers.js:463:21)
              2022-02-08 20:45:41.109 - error: javascript.0 (18309) Error in callback: TypeError: Cannot read property 'toFixed' of undefined
              2022-02-08 20:45:41.109 - error: javascript.0 (18309) at MakeTable (script.js.common.BatterienÜberwachung:610:75)
              2022-02-08 20:45:41.109 - error: javascript.0 (18309) at main (script.js.common.BatterienÜberwachung:266:5)
              2022-02-08 20:45:41.109 - error: javascript.0 (18309) at Object. (script.js.common.BatterienÜberwachung:126:13)
              2022-02-08 20:45:41.109 - error: javascript.0 (18309) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1988:38)
              2022-02-08 20:45:41.110 - error: javascript.0 (18309) at processImmediate (internal/timers.js:463:21)
              

              Dieses "getState "alias.0.TEST.lowBatt" not found" ist wohl das Problem. Ich hab dann aber auch noch lowbat wieder nach lowBatt zurückbenannt, aber immer noch die gleichen Fehler.

              Was mache ich falsch?

              P 1 Antwort Letzte Antwort
              0
              • Dominik F.D Dominik F.

                @pittini

                Ich bekomme folgenden Log von dem Skript:

                avascript.0
                2022-02-08 18:50:48.543	info	script.js.common.Auswertung_Batterien: Reaching Meldung(), msg=Batteriestand (2.29 V) unter Limit (2.32 V) im EG Diele bei Gerät EG_Diele Heizkörper
                

                Problem an der Sache ist, der Batteriestand ist 2,4V, das wird auch in der Tabelle richtig erkannt:

                Unbenannt.PNG

                Hast du eine Idee was das Problem sein könnte?

                P Offline
                P Offline
                Pittini
                Developer
                schrieb am zuletzt editiert von
                #518

                @dominik-f Würde ich mal loggen welche Werte da auftreten, irgendwoher muß das Skript die 2,29 Volt aus der Meldung ja herhaben.

                Dominik F.D 1 Antwort Letzte Antwort
                0
                • T Tobi81

                  Ich denke ich habe den Alias Adapter erfolgreich eingerichtet und ein Testdevice sieht jetzt so aus:

                  Bildschirmfoto 2022-02-08 um 20.39.08.png

                  Ich habe LowBatt nach lowbat umbenannt und die Funktion BatterieSpannung_30 hinzugefügt. Wenn ich jetzt das Script von Pittini neustarte bekomme ich folgende Fehlermeldungen:

                  2022-02-08 20:45:41.094 - warn: javascript.0 (18309) getState "alias.0.TEST.lowBatt" not found (3)
                  2022-02-08 20:45:41.095 - warn: javascript.0 (18309) at Init (script.js.common.BatterienÜberwachung:160:31)
                  2022-02-08 20:45:41.095 - warn: javascript.0 (18309) at main (script.js.common.BatterienÜberwachung:261:5)
                  2022-02-08 20:45:41.096 - warn: javascript.0 (18309) at Object. (script.js.common.BatterienÜberwachung:126:13)
                  2022-02-08 20:45:41.096 - warn: javascript.0 (18309) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1988:38)
                  2022-02-08 20:45:41.096 - warn: javascript.0 (18309) at processImmediate (internal/timers.js:463:21)
                  2022-02-08 20:45:41.109 - error: javascript.0 (18309) Error in callback: TypeError: Cannot read property 'toFixed' of undefined
                  2022-02-08 20:45:41.109 - error: javascript.0 (18309) at MakeTable (script.js.common.BatterienÜberwachung:610:75)
                  2022-02-08 20:45:41.109 - error: javascript.0 (18309) at main (script.js.common.BatterienÜberwachung:266:5)
                  2022-02-08 20:45:41.109 - error: javascript.0 (18309) at Object. (script.js.common.BatterienÜberwachung:126:13)
                  2022-02-08 20:45:41.109 - error: javascript.0 (18309) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1988:38)
                  2022-02-08 20:45:41.110 - error: javascript.0 (18309) at processImmediate (internal/timers.js:463:21)
                  

                  Dieses "getState "alias.0.TEST.lowBatt" not found" ist wohl das Problem. Ich hab dann aber auch noch lowbat wieder nach lowBatt zurückbenannt, aber immer noch die gleichen Fehler.

                  Was mache ich falsch?

                  P Offline
                  P Offline
                  Pittini
                  Developer
                  schrieb am zuletzt editiert von Pittini
                  #519

                  @tobi81 Nach jeder Änderung an Aufzählungen MUß der JS Adapter neu gestartet werden, sonst kriegt das System davon nix mit. Und jedes Skript welche die geänderten Aufzählungen nutzt muß auch neugestartet werden, damit die Trigger aktualisiert werden.

                  B 1 Antwort Letzte Antwort
                  0
                  • P Pittini

                    @dominik-f Würde ich mal loggen welche Werte da auftreten, irgendwoher muß das Skript die 2,29 Volt aus der Meldung ja herhaben.

                    Dominik F.D Offline
                    Dominik F.D Offline
                    Dominik F.
                    schrieb am zuletzt editiert von
                    #520

                    @pittini

                    Du hattest recht....aus irgendeinem Grund springt der Batteriestate immer mal wieder kurz nach unten.

                    Unbenannt.PNG

                    1 Antwort Letzte Antwort
                    0
                    • P Pittini

                      @tobi81 Nach jeder Änderung an Aufzählungen MUß der JS Adapter neu gestartet werden, sonst kriegt das System davon nix mit. Und jedes Skript welche die geänderten Aufzählungen nutzt muß auch neugestartet werden, damit die Trigger aktualisiert werden.

                      B Offline
                      B Offline
                      babl
                      schrieb am zuletzt editiert von
                      #521

                      @pittini hast du das mitbekommen mit den neuen Änderungen für die xiaomi Batterie Geräte.

                      https://github.com/Koenkk/zigbee2mqtt/issues/8499#issuecomment-1032422285

                      Sie haben jetzt andere voltanpassungen durchgeführt, sollte man da dein Script auch eventuell angleichen?

                      P 1 Antwort Letzte Antwort
                      0
                      • B babl

                        @pittini hast du das mitbekommen mit den neuen Änderungen für die xiaomi Batterie Geräte.

                        https://github.com/Koenkk/zigbee2mqtt/issues/8499#issuecomment-1032422285

                        Sie haben jetzt andere voltanpassungen durchgeführt, sollte man da dein Script auch eventuell angleichen?

                        P Offline
                        P Offline
                        Pittini
                        Developer
                        schrieb am zuletzt editiert von
                        #522

                        @babl 3V sind 3V, wie oder woher die berechnet werden is mir egal. sehe hier keinerlei Anpassungsnotwendigkeit.

                        B 1 Antwort Letzte Antwort
                        0
                        • P Pittini

                          @babl 3V sind 3V, wie oder woher die berechnet werden is mir egal. sehe hier keinerlei Anpassungsnotwendigkeit.

                          B Offline
                          B Offline
                          babl
                          schrieb am zuletzt editiert von
                          #523

                          @pittini aber bei 2.85V werden die bei zigbee bereits mit 0% gelistet

                          P 1 Antwort Letzte Antwort
                          0
                          • B babl

                            @pittini aber bei 2.85V werden die bei zigbee bereits mit 0% gelistet

                            P Offline
                            P Offline
                            Pittini
                            Developer
                            schrieb am zuletzt editiert von
                            #524

                            @babl Wieviel Prozent zigbee da angibt, ist doch egal solange Du dem Skript den Spannungsdatenpunkt gibst und nicht den mit den Prozenten. Dann errechnet das Skript das selber. Und all meine Xiaomis liefern beides.

                            B 1 Antwort Letzte Antwort
                            0
                            • P Pittini

                              @babl Wieviel Prozent zigbee da angibt, ist doch egal solange Du dem Skript den Spannungsdatenpunkt gibst und nicht den mit den Prozenten. Dann errechnet das Skript das selber. Und all meine Xiaomis liefern beides.

                              B Offline
                              B Offline
                              babl
                              schrieb am zuletzt editiert von
                              #525

                              @pittini das stimmt schon, nur hat man jetzt 2 verschiedene anzeigen.

                              bei dir im script steht er bei 98% Batterieleistung

                              und im Zigbee steht er mit 47% Batterieleistung

                              Das ist halt auch etwas blöd.

                              1 Antwort Letzte Antwort
                              0
                              • M Offline
                                M Offline
                                Matt77CHE
                                schrieb am zuletzt editiert von Matt77CHE
                                #526

                                gelöscht

                                1 Antwort Letzte Antwort
                                0
                                • Nightfly1983N Offline
                                  Nightfly1983N Offline
                                  Nightfly1983
                                  schrieb am zuletzt editiert von
                                  #527

                                  Habe seit heute auch paar Probleme mit dem Script, kann mir jemand weiterhelfen?
                                  Das Script bringt folgende Fehler:

                                  14:44:46.922	info	javascript.0 (35201) script.js.common.Batterieueberwachung: CheckDeadBatt() State for 19 doesnt exists
                                  14:44:46.929	error	javascript.0 (35201) at MakeTable (script.js.common.Batterieueberwachung:610:75)
                                  14:44:46.929	error	javascript.0 (35201) at CheckDeadBatt (script.js.common.Batterieueberwachung:366:13)
                                  14:44:46.929	error	javascript.0 (35201) at CheckBatterys (script.js.common.Batterieueberwachung:465:5)
                                  14:44:46.929	error	javascript.0 (35201) at Object.<anonymous> (script.js.common.Batterieueberwachung:726:13)
                                  
                                  P 1 Antwort Letzte Antwort
                                  0
                                  • Nightfly1983N Nightfly1983

                                    Habe seit heute auch paar Probleme mit dem Script, kann mir jemand weiterhelfen?
                                    Das Script bringt folgende Fehler:

                                    14:44:46.922	info	javascript.0 (35201) script.js.common.Batterieueberwachung: CheckDeadBatt() State for 19 doesnt exists
                                    14:44:46.929	error	javascript.0 (35201) at MakeTable (script.js.common.Batterieueberwachung:610:75)
                                    14:44:46.929	error	javascript.0 (35201) at CheckDeadBatt (script.js.common.Batterieueberwachung:366:13)
                                    14:44:46.929	error	javascript.0 (35201) at CheckBatterys (script.js.common.Batterieueberwachung:465:5)
                                    14:44:46.929	error	javascript.0 (35201) at Object.<anonymous> (script.js.common.Batterieueberwachung:726:13)
                                    
                                    P Offline
                                    P Offline
                                    Pittini
                                    Developer
                                    schrieb am zuletzt editiert von
                                    #528

                                    @nightfly1983 Naja, steht ja fast im Klartext da

                                    State for 19 doesnt exists
                                    

                                    Keine Ahnung was "19" ist, aber ich würde vermuten Du hast ein Gerät gelöscht, oder iwas geändert? Ohne zu wissen was Du gemacht hast oder ausführliches Log, kann ich nur raten.

                                    Nightfly1983N reindeer-webR 2 Antworten Letzte Antwort
                                    0
                                    • P Pittini

                                      @nightfly1983 Naja, steht ja fast im Klartext da

                                      State for 19 doesnt exists
                                      

                                      Keine Ahnung was "19" ist, aber ich würde vermuten Du hast ein Gerät gelöscht, oder iwas geändert? Ohne zu wissen was Du gemacht hast oder ausführliches Log, kann ich nur raten.

                                      Nightfly1983N Offline
                                      Nightfly1983N Offline
                                      Nightfly1983
                                      schrieb am zuletzt editiert von
                                      #529

                                      @pittini Na das hat mir doch schon voll geholfen :smile:
                                      Ein Sensor hat keinen Wert bei der Spannung geliefert und damit kam es zustande.
                                      Brauchte nur den Denkanstoß, danke dir

                                      1 Antwort Letzte Antwort
                                      0
                                      • dog-rgbD Offline
                                        dog-rgbD Offline
                                        dog-rgb
                                        schrieb am zuletzt editiert von
                                        #530

                                        Hallo, wenn ein Gerät ausfällt und somit DeadDeviceCount>0 ist, wird AllBatterysOK nicht auf False gesetzt. Ich hätte gerne einen Datenpunkt der meldet wenn irgendein Gerät ein Problem hat, und nicht nur wenn der Batteriestand zu niedrig ist.

                                        P 1 Antwort Letzte Antwort
                                        0
                                        • dog-rgbD dog-rgb

                                          Hallo, wenn ein Gerät ausfällt und somit DeadDeviceCount>0 ist, wird AllBatterysOK nicht auf False gesetzt. Ich hätte gerne einen Datenpunkt der meldet wenn irgendein Gerät ein Problem hat, und nicht nur wenn der Batteriestand zu niedrig ist.

                                          P Offline
                                          P Offline
                                          Pittini
                                          Developer
                                          schrieb am zuletzt editiert von
                                          #531

                                          @dog-rgb Mach bitte ein Issue auf Git damits nicht vergessen wird. Wird aber auf jeden Fall dauern, ich hab grad null Zeit.

                                          dog-rgbD 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

                                          618

                                          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