Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [gelöst]-Alle Objekte eines Ordners...

    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

    [gelöst]-Alle Objekte eines Ordners...

    This topic has been deleted. Only users with topic management privileges can see it.
    • liv-in-sky
      liv-in-sky @Peterfrosta last edited by

      @Peterfrosta

      der rest wird auch noch 🙂

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

        @Peterfrosta sagte in [gelöst]-Alle Objekte eines Ordners...:

        abhängig vom letzten Änderungsdatum(Zeit) des entsprechende Objekts

        lastChange = getState(id).lc;
        
        P 1 Reply Last reply Reply Quote 0
        • P
          Peterfrosta last edited by Peterfrosta

          danke, das hatte ich zum glück schon gefunden... aber:

          wenn ichjetzt wissen möchte wie alt der status schon ist, würde ich ja denken, dass ich folgenden prüfen müsste:

           console.log((Date.now()-getState(id).lc)/1000);
          

          Date.now()

          der Output ist dann aber :
          11121.896

          was würde ich ohne dich nur machen 😉

          hm...

          edit:

          und ich hatte den state natürlich wenige Sekunden zuvor geändern. so dass ich eine Zahl in der Größenordnung 1-10 erwartet hätte

          P liv-in-sky 2 Replies Last reply Reply Quote 0
          • P
            Peterfrosta @paul53 last edited by

            @paul53 Ach da ist ja wer Neues. Danke dir!

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

              @Peterfrosta said in [gelöst]-Alle Objekte eines Ordners...:

              der Output ist dann aber :
              11121.896

              Vergisst es. hatte das falsche Objekt bearbeitet. Entschuldigt bitte.

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

                gibt es nirgens eine Sammlung (Wiki) für die Sachen auf die man mit getState() oder getObject() zugreifen kann?

                getObject().common.name
                getState(id).val
                getState(id).lc

                kenne ich ja nun nur von euch hier.

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

                  @Peterfrosta sagte:

                  Sammlung (Wiki) für die Sachen auf die man mit getState()

                  Doku

                  @Peterfrosta sagte in [gelöst]-Alle Objekte eines Ordners...:

                  getObject() zugreifen kann?

                  Doku

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

                    @paul53 DAAANKE 😘

                    1 Reply Last reply Reply Quote 0
                    • liv-in-sky
                      liv-in-sky @Peterfrosta last edited by liv-in-sky

                      @Peterfrosta sagte in [gelöst]-Alle Objekte eines Ordners...:

                      console.log((Date.now()-getState(id).lc)/1000);

                      eher sowas:

                      log(((new Date().getTime()-getState(myid).lc))/1000)
                      

                      aktuelle zeit in ms minus zeit (lastchange) in millisekunden geteilt durch 1000 sind gleich sekunden

                      noch ein kleiner tipp, wenn du mit blockly besser zurecht kommst. du kannst die erstmal ein blockly machen und dieses blockly in js ansehen - dies kannst du dann in deinen js-script kopieren

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

                        So ich bin schon was weiter.. habe ein paar Testfunktionen für die Verarbeitungs der Wartungsstände...
                        Klappte auch erstmal... nun hatte ich geshen, dass die ganze for.each sachen für get alle states und dessen infos sich oft wiederholt -->also ausgelagert in eine eigene Funktion GetWartungsStates()

                        //hier liegen alle Wartungobjekte
                        var root_path="javascript.0.waschstr.wartung";
                        //var alle_wartungen = $('state[id=*](functions="wartung_14tage")');       //Alternative mit "Aufzählung"     //Objekte könnten dann verteilt sein 
                        
                        //definition der Wartungseinträge zum erstmaligen Erstellen der Objekte
                        var states_init = [
                                        ["Cat350 oelen", 30 ], [ "Kameras \"abledern\"", 30 ],
                                        ["Schlamfänge konmtrollieren", 14 ], [ "Lager fetten", 14 ],
                                        ["Kettengetriebe Oelwechseln", 30 ], [ "Cat350 OElwechsel", 30 ], [ "Kompressor OEl Tauschen", 30 ]
                         ] ;
                        
                        var all_wartungs_states=[];     //globale halte Variable der WartungsObjekte
                        
                        
                        //InitWartungStates(states_init);        //erstellt alle WartungsObjekte
                        //GetWartungsStates();              //fragt alle Wartungsobjekte ab
                        PrintWartungStates();               //gebe alle Einträge aus
                        
                        //PrintWartungStates_alt();           // war ohne GetWartungsStates() und Array für die Werte und Objekte
                        //IsWartungFaellig();
                        
                        
                        
                        //########################################################
                        //##    Funktionenen
                        
                        function InitWartungStates(wartung) {
                            wartung.forEach(function(id,i) {
                                createState(root_path+"."+id[0], false, {
                                        read: true,
                                        write: true,
                                        name: id[0],            ///nName/text der wartung
                                        type: "number",
                                        def: 0,
                                        key: i,                 //jede wartung bekommt eigene nummer (kurzbefehl)
                                        interval:id[1]          //alle x Tage wird drann erinnert
                                });
                            });
                        }
                        
                        // Versuch mit lokaler und globaler Variable 
                        // hier klappt beides aber.. siehe >> function PrintWartungStates(ordner)
                        function GetWartungsStates(){
                            var alter_sek;      //hilfsvariable  für wartungs_state["alter_tage"]
                        
                            //var all_wartungs_states=[];       
                        
                            var  wartungs_state= {
                                name: "leer",
                                state: 0,
                                interval: 0,
                                key: 0,
                                alter_tage: 0 
                            };
                        
                            //gehe jedes Objekt im ordner durch
                            $(root_path+".*").each(function(id, i) {
                        
                                alter_sek = Math.floor((Date.now()-getState(id).lc)/1000);
                                        
                                wartungs_state["alter_tage"] = Math.floor(alter_sek/60/60/24);
                                wartungs_state["name"]= getObject(id).common.name;
                                wartungs_state["state"]= getState(id).val;
                                wartungs_state["interval"]= getObject(id).common.interval;
                                wartungs_state["key"]= getObject(id).common.key;
                        
                                all_wartungs_states.push(wartungs_state);
                                console.log("**Name"+i+": "+wartungs_state["name"]+"   Interval: "+wartungs_state["interval"]+"   State: "+wartungs_state["state"]+"    Key: "+wartungs_state["key"]+" \n  Alter Sekunden:  "+wartungs_state["sekunden"]+"\n");
                                console.log("**Name"+i+": "+all_wartungs_states[i]["name"]+"   Interval: "+all_wartungs_states[i]["interval"]+"   State: "+all_wartungs_states[i]["state"]+"    Key: "+all_wartungs_states[i]["key"]+" \n  Alter Sekunden:  "+all_wartungs_states[i]["sekunden"]+"\n");
                            });
                            //return all_wartungs_states;
                        }
                        
                        //Teste return Objekt-Array von GetWartungsStates()
                        //Konsolenausgabe aller (Wartungsobjekte) returned from GetWartungsStates()
                        function PrintWartungStates(ordner){
                           // var all_wartungs_states2=[];   
                        
                            GetWartungsStates();
                        
                            all_wartungs_states.forEach(function(wartungs_state, i) {
                               console.log("--Name"+i+": "+wartungs_state["name"]+"   Interval: "+wartungs_state["interval"]+"   State: "+wartungs_state["state"]+"    Key: "+wartungs_state["key"]+" \n  Alter Sekunden:  "+wartungs_state["sekunden"]+"\n");
                               console.log("--Name"+i+": "+all_wartungs_states[i]["name"]+"   Interval: "+all_wartungs_states[i]["interval"]+"   State: "+all_wartungs_states[i]["state"]+"    Key: "+all_wartungs_states[i]["key"]+" \n  Alter Sekunden:  "+all_wartungs_states[i]["sekunden"]+"\n");
                            });  
                        }
                        
                        

                        die doppelten Consolenausgaben in GetWartungsStates() und PrintWartungStates() sind nur zu debugzwecken drin...

                        Die PrintWartungStates() läuft zwar die richtige Anzahl oft durch die Each doch leider findet sich in jedem der Arrays der selbe Inhalt - der des letztens Objektes.

                        [info ] javascript.0.Wartung_prozedual: **Name0: Cat350 OElwechsel   Interval: 30   State: false    Key: 5   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name0: Cat350 OElwechsel   Interval: 30   State: false    Key: 5   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name1: Cat350 oelen   Interval: 30   State: false    Key: 0   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name1: Cat350 oelen   Interval: 30   State: false    Key: 0   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name2: Kettengetriebe Oelwechseln   Interval: 30   State: false    Key: 4 Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name2: Kettengetriebe Oelwechseln   Interval: 30   State: false    Key: 4   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name3: Kompressor OEl Tauschen   Interval: 30   State: false    Key: 6   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name3: Kompressor OEl Tauschen   Interval: 30   State: false    Key: 6   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name4: Lager fetten   Interval: 14   State: false    Key: 3   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name4: Lager fetten   Interval: 14   State: false    Key: 3   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name5: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: **Name5: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name0: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name0: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name1: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name1: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name2: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name2: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name3: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name3: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name4: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name4: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name5: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        [info ] javascript.0.Wartung_prozedual: --Name5: Schlamfänge konmtrollieren   Interval: 14   State: false    Key: 2   Alter Sekunden:  undefined
                        31.7.2020, 01:12:18.689	[info ] javascript.0.Wartung_prozedual: registered 1 subscription and 0 schedules
                        

                        Das Script oben sollte eigentlich alles Nötige mitbringen und direkt ausführbar sein. Erstellt euch höchstens einen Ordner mit Objekten 😉
                        Dann versteht man mich vllt besser als mit meiner schriftlichen Ausführung 😉

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

                          Habe die Ursache gefunden - wenn auch ich nicht ganz nachvollziehen können:
                          initialize the object holding variable inside the for loop beginning

                          1 Reply Last reply Reply Quote 0
                          • First post
                            Last post

                          Support us

                          ioBroker
                          Community Adapters
                          Donate

                          839
                          Online

                          31.9k
                          Users

                          80.2k
                          Topics

                          1.3m
                          Posts

                          blockly javascript
                          3
                          27
                          2360
                          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