Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Script Xiaomi Battery leer ?

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    UNSOLVED Script Xiaomi Battery leer ?

    This topic has been deleted. Only users with topic management privileges can see it.
    • MyzerAT
      MyzerAT last edited by

      hast du ihn erst angelernt? wenn ja dauert das bis zu ein paar stunden!

      1 Reply Last reply Reply Quote 0
      • StM47
        StM47 last edited by

        Ja habe ich.
        Die Anderen, welche ich gleichzeitig angelernt habe, liefern aber direkt die Daten

        1 Reply Last reply Reply Quote 0
        • MyzerAT
          MyzerAT last edited by MyzerAT

          die Temp und Feuchtigkeit liefert er ja, hauch ihn an , dann siehst ja eh ob er reagiert, Status der Batterie kann dennoch ewig dauern!

          1 Reply Last reply Reply Quote 0
          • StM47
            StM47 last edited by

            Ok! Danke erstmal. Werde ich beobachten.

            1 Reply Last reply Reply Quote 0
            • P
              passuff last edited by passuff

              Wollte jetzt den Raumnamen entfernen aber irgendwie habe ich das skript zerschossen:

              const idVis = 'Batterie.HomematicBatterietausch';
              const batt = $('hm-rpc.0.*.LOWBAT');
               
              createState(idVis, '', {type: 'string'});
               
              function lowBatt() {
              	console.log('lowbat Homematic wird ausgeführt');
                  var low = [];
                  batt.each(function (id, i) {
              	if(getState(id).val == true) {
              			id = id.split('.');
              			id = 'hm-rpc.0.' + id[2];
                          low.push(getObject(id).common.name); // Kanal-Name: Raum
                  }
                       	
              	});
              	setState(idVis, low.join(','), true);		
              }
              
              
              schedule('*/5 * * * * *', lowBatt); // jeden Tag 
              //schedule('{"time":{"exactTime":true,"start":"18:00"},"period":{"days":1}}', lowBatt)
               
               
               
              

              Folgendes Warn im Log:

              javascript.0 2019-08-04 21:53:45.008 warn at Timer.processTimers (timers.js:223:10)
              javascript.0 2019-08-04 21:53:45.008 warn at listOnTimeout (timers.js:263:5)
              javascript.0 2019-08-04 21:53:45.008 warn at tryOnTimeout (timers.js:300:5)
              javascript.0 2019-08-04 21:53:45.007 warn at ontimeout (timers.js:436:11)
              javascript.0 2019-08-04 21:53:45.007 warn at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/schedule.js:501:7)
              javascript.0 2019-08-04 21:53:45.007 warn at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/schedule.js:543:11
              javascript.0 2019-08-04 21:53:45.007 warn at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/schedule.js:173:10)
              javascript.0 2019-08-04 21:53:45.007 warn at Job.nodeSchedule.scheduleJob [as job] (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1191:34)
              javascript.0 2019-08-04 21:53:45.007 warn at Object.lowBatt (script.js.common.Batteriestatus.Batteriestatus_Homematic:9:10)
              javascript.0 2019-08-04 21:53:45.007 warn at Object.result.each (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:778:29)
              javascript.0 2019-08-04 21:53:45.006 warn at script.js.common.Batteriestatus.Batteriestatus_Homematic:10:5
              javascript.0 2019-08-04 21:53:45.004 warn getState "hm-rpc.0.PEQ0508233.0.LOWBAT" not found (3) states[id]=null
              javascript.0 2019-08-04 21:53:45.001 info script.js.common.Batteriestatus.Batteriestatus_Homematic: lowbat Homematic wird ausgeführt

              Glasfaser paul53 2 Replies Last reply Reply Quote 0
              • Glasfaser
                Glasfaser @passuff last edited by Glasfaser

                @passuff sagte in Script Xiaomi Battery leer ?:

                …………………….> javascript.0 2019-08-04 21:53:45.004 warn getState "hm-rpc.0.PEQ0508233.0.LOWBAT" not found (3) states[id]=null
                ………………….

                Dein Skript macht kein Fehler .

                Da ist ein Fehler im Datenpunkt hm-rpc.0.PEQ0508233.0.LOWBAT not found (3) states[id]=null

                Schau mal nach ob da ein Wert vorhanden ist !?

                P 1 Reply Last reply Reply Quote 0
                • P
                  passuff @Glasfaser last edited by

                  @Glasfaser
                  Der Datenpunkt ist ein Homematic Schaltaktor. Der hat, wie andere Geräte auch, keinen Batteriestatus. Warum stört sich das Skript daran?
                  Darüber hinaus funktioniert die Bedingung ( == true) nicht. Es werden schlussendlich alle Homematicgeräte mit LOWBAT gelistet, auch die die false sind...

                  Glasfaser P 2 Replies Last reply Reply Quote 0
                  • Glasfaser
                    Glasfaser @passuff last edited by

                    @passuff

                    Sieht es nicht bei dir so aus !?

                    www.JPG

                    P 1 Reply Last reply Reply Quote 0
                    • P
                      passuff @Glasfaser last edited by

                      @Glasfaser

                      Nein, wie gesagt das Gerät ist eine Steckdose. Diese hat keine Batterie und daher auch keinen Batteriestatus...

                      Glasfaser 1 Reply Last reply Reply Quote 0
                      • Glasfaser
                        Glasfaser @passuff last edited by

                        @passuff

                        Sorry ...mit der Angabe " Homematic Schaltaktor " konnte ich leider nicht erlesen , das es sich um eine Steckdose handelt .

                        Glasfaser 1 Reply Last reply Reply Quote 0
                        • Glasfaser
                          Glasfaser @Glasfaser last edited by

                          @Glasfaser

                          Hier die HM Steckdose ( Keine IP )

                          Es gibt da ein Datenpunkt !

                          steckdose.JPG

                          P 1 Reply Last reply Reply Quote 0
                          • P
                            passuff @Glasfaser last edited by

                            @Glasfaser
                            Muss mich entschuldigen. Ich habe mich im Gerät geirrt. Du hattest völlig recht:

                            2019-08-04_22-38-43.jpg

                            Scheint als hat de Fernbedienung keinen Empfang und sendet daher weder true noch false.

                            Glasfaser 1 Reply Last reply Reply Quote 0
                            • Glasfaser
                              Glasfaser @passuff last edited by

                              @passuff

                              Richtig … kein Empfang ….

                              fern.JPG

                              1 Reply Last reply Reply Quote 0
                              • P
                                passuff @passuff last edited by

                                @passuff sagte in Script Xiaomi Battery leer ?:

                                Darüber hinaus funktioniert die Bedingung ( == true) nicht. Es werden schlussendlich alle Homematicgeräte mit LOWBAT gelistet, auch die die false sind...

                                Das erschließt sich mir allerdings immer noch nicht...

                                Glasfaser 1 Reply Last reply Reply Quote 0
                                • Glasfaser
                                  Glasfaser @passuff last edited by

                                  @passuff

                                  Kann leider nicht testen , da ich gerade keine leere Batterie habe , aber dein Script läuft ohne Fehler bei mir im LOG .

                                  P 1 Reply Last reply Reply Quote 0
                                  • P
                                    passuff @Glasfaser last edited by

                                    @Glasfaser

                                    Ich habe auch keine leere Batterie. Dennoch habe ich im erzeugten Datenpunkt alle HM Geräte gelistet..

                                    Glasfaser 1 Reply Last reply Reply Quote 0
                                    • Glasfaser
                                      Glasfaser @passuff last edited by Glasfaser

                                      @passuff

                                      Habe mal den Wert Lowbat händisch auf true gesetzt .
                                      Und die gleiche Fehlermeldungen wie bei Dir !!!

                                      1 Reply Last reply Reply Quote 0
                                      • paul53
                                        paul53 @passuff last edited by

                                        @passuff sagte:

                                        warn getState "hm-rpc.0.PEQ0508233.0.LOWBAT" not found (3) states[id]=null

                                        Anscheinend hat das Objekt noch keinen Zustand ? Dann gib mal manuell den Wert false ein.

                                        1 Reply Last reply Reply Quote 0
                                        • P
                                          passuff last edited by

                                          Das führt lediglich dazu, dass die Fehlermeldungen verschwinden. Die Bedingung wird immer noch falsch ausgewertet bzw alle Sensoren werden als lowbat = true erkannt.

                                          paul53 1 Reply Last reply Reply Quote 0
                                          • paul53
                                            paul53 @passuff last edited by paul53

                                            @passuff sagte:

                                            alle Sensoren werden als lowbat = true erkannt.

                                            Wie sieht das Log aus, wenn in Zeile 10 ein zusätzliches Log eingefügt wird ?

                                                batt.each(function (id, i) {
                                                    log(id + ': ' + getState(id).val);
                                            
                                            P 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            435
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            blockly
                                            19
                                            93
                                            8822
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo