Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [GELOEST]Log Daten im VIS anzeigen

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    [GELOEST]Log Daten im VIS anzeigen

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

      Hallo,

      hat jemand eine Idee wie man die ioBroker log Datei z.B. per Basic String Widget im VIS anzeigen lassen kann?

      Schön wäre es wenn mann selektieren könnte! Z.b. nur die vom javascript Adapter kommen.

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

        Das geht momentan nur mit einem Skript.

        Du liest jede Sekunde die Datei /opt/iobroker/log/iobroker.YYYY-MM-DD.log aus und filterst das, wie du es willst.

        Danach in eine Variable (z.B. javascript.0.log) raus schreiben.

        Obwohl man doch direkt in diese Variable raus schreiben konnte. Einfach ein Global Skript anlegen:

        createState('log', '');
        function toLog(text) {
            console.log(text);
            var lines = getState('log').val;
            lines = lines.split('\n');
            lines.push(text);
            if (lines.length > 25) lines.splice(0,1);
            setState('log', lines.join('\n'), true);
        }
        
        

        Und dann überall statt log dann toLog benutzen.

        1 Reply Last reply Reply Quote 0
        • blauholsten
          blauholsten Developer last edited by

          Hi,

          danke! Klappt wunderbar, bekommt man es auch hin das bei jeden Funktionsaufruf ein Zeilenumbruch gemacht wird denn das klappt nicht. (obwohl ich mir vorstellen könnte das das in deinem Code \n ein Umbruch bedeutet??)
          671_unbenannt.jpg

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

            createState('log', '');
            function toLog(text) {
                console.log(text);
                var lines = getState('log').val;
                lines = lines.split('
            ');
                lines.push(text);
                if (lines.length > 25) lines.splice(0,1);
                setState('log', lines.join('
            '), true);
            }
            
            
            1 Reply Last reply Reply Quote 0
            • blauholsten
              blauholsten Developer last edited by

              @Bluefox:

              createState('log', '');
              function toLog(text) {
                  console.log(text);
                  var lines = getState('log').val;
                  lines = lines.split('
              ');
                  lines.push(text);
                  if (lines.length > 25) lines.splice(0,1);
                  setState('log', lines.join('
              '), true);
              }
              
              ```` `  
              

              hat leider nicht geklappt….
              671_unbenannt.jpg

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

                In welchem Widget zeigst du es an?

                1 Reply Last reply Reply Quote 0
                • blauholsten
                  blauholsten Developer last edited by

                  @Bluefox:

                  In welchem Widget zeigst du es an? `
                  Basic string

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

                    @blauholsten:

                    @Bluefox:

                    In welchem Widget zeigst du es an? Basic string
                    Nimm "basic-string unescaped"

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

                      Frage: sieht man nur die logs, die man im JavaScript Adapter ausgibt (ähnlich dem Ereignisprotokoll) oder auch die Logs der Adapter?

                      Gruß

                      Pix

                      Gesendet von meinem iPhone mit Tapatalk

                      1 Reply Last reply Reply Quote 0
                      • blauholsten
                        blauholsten Developer last edited by

                        @blauholsten:

                        Hallo,

                        hat jemand eine Idee wie man die ioBroker log Datei z.B. per Basic String Widget im VIS anzeigen lassen kann?

                        Schön wäre es wenn mann selektieren könnte! Z.b. nur die vom javascript Adapter kommen. `

                        Hi,

                        nur die Logs die du selber im Script bestimmst…in obrigen Fall immer wenn man "toLog("z.B. hallo")" schreibt.

                        @Bluefox:

                        @blauholsten:

                        @Bluefox:

                        In welchem Widget zeigst du es an? Basic string
                        Nimm "basic-string unescaped" `

                        Das haut wunderbar hin!!! (aber erst nach der Veränderung)

                        1 Reply Last reply Reply Quote 0
                        • blauholsten
                          blauholsten Developer last edited by

                          671_unbenannt.jpg

                          wie bekomme ich eine "normale" Datum + Zeit angezeigt?

                          Ich habe mir eine globale Variable angelegt der ich das Object new Date() zuweise.

                          Ich möchte den Zeitstempel z.B. nur so angezeigt bekommen 10.10.2015 12:23:09

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

                            Einfachste ist:

                            (new Date()).toLocaleString()
                            

                            oder so:

                            function getTimeAsString(d) {
                                var date = d || new Date();
                                return date.getFullYear() + '.' + ('0' + (date.getMonth() + 1)).slice(-2) + '.' + ('0' + date.getDate()).slice(-2) + ' '+
                             ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2) + ':' +  ('0' + date.getSeconds()).slice(-2);    
                            }
                            console.log(getTimeAsString());
                            console.log(getTimeAsString(new Date('2015.02.02')));
                            
                            
                            1 Reply Last reply Reply Quote 0
                            • blauholsten
                              blauholsten Developer last edited by

                              @Bluefox:

                              Einfachste ist:

                              (new Date()).toLocaleString()
                              ```` `  
                              

                              Geht leider nicht (Benutze Chrome)

                              //***************GLOBALES_SCRIPT*********************
                              createState('log', '');
                              zeit = (new Date()).toLocaleString();//setze ich bei Bedarf vor toLog
                              
                              function toLog(text) 
                              {
                                  console.log(text);
                                  var lines = getState('log').val;
                                  lines = lines.split('
                              ');
                                  lines.push(text);
                                  if (lines.length > 25) lines.splice(0,1);
                                  setState('log', lines.join('
                              '), true);
                              }
                              
                              
                              1 Reply Last reply Reply Quote 0
                              • Bluefox
                                Bluefox last edited by

                                @blauholsten:

                                Geht leider nicht (Benutze Chrome) `
                                Es ist nicht wichtig, was für einen Browser du nutzst. Es wird auf dem Server ausgeführt.

                                Und es gibt wirklich die Funktion nicht in node.js :?

                                Du musst es so machen:

                                //***************GLOBALES_SCRIPT*********************
                                createState('log', '');
                                
                                function getTimeAsString(d) {
                                    var date = d || new Date();
                                    return date.getFullYear() + '.' + ('0' + (date.getMonth() + 1)).slice(-2) + '.' + ('0' + date.getDate()).slice(-2) + ' '+
                                 ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2) + ':' +  ('0' + date.getSeconds()).slice(-2);    
                                }
                                function toLog(text, addTimestamp) 
                                {
                                    console.log(text);
                                    var lines = getState('log').val;
                                    lines = lines.split('
                                ');
                                    if (addTimestamp) {
                                            lines.push(getTimeAsString() + ': ' + text);
                                    } else {
                                            lines.push(text);
                                    }
                                    if (lines.length > 25) lines.splice(0,1);
                                    setState('log', lines.join('
                                '), true);
                                }
                                
                                

                                Und dann, immer wenn Zeitstempel da sein muss:

                                toLog('mit zeitstempel', true);
                                toLog('ohne zeitstempel');
                                
                                S 1 Reply Last reply Reply Quote 0
                                • blauholsten
                                  blauholsten Developer last edited by

                                  @bluefox:

                                  Perfekt DANKE

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

                                    @Bluefox:

                                    Das geht momentan nur mit einem Skript.

                                    Du liest jede Sekunde die Datei /opt/iobroker/log/iobroker.YYYY-MM-DD.log aus und filterst das, wie du es willst.

                                    Danach in eine Variable (z.B. javascript.0.log) raus schreiben.

                                    Obwohl man doch direkt in diese Variable raus schreiben konnte. Einfach ein Global Skript anlegen:

                                    createState('log', '');
                                    function toLog(text) {
                                        console.log(text);
                                        var lines = getState('log').val;
                                        lines = lines.split('\n');
                                        lines.push(text);
                                        if (lines.length > 25) lines.splice(0,1);
                                        setState('log', lines.join('\n'), true);
                                    }
                                    
                                    

                                    Und dann überall statt log dann toLog benutzen. `

                                    Guten Morgen zusammen!

                                    Ich würde auch gerne mir mein Log in Vis anzeigen lassen aber ich steig da irgendwie nicht durch mit dem was Bluefox da meint!

                                    Ich meine wie filtere ich dann da was raus?

                                    Und was meint Bluefox mit log tolog?

                                    Kann mir da vielleicht jemand helfen?

                                    Johnny

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

                                      @PrinzEisenherz1:

                                      @Bluefox:

                                      Das geht momentan nur mit einem Skript.

                                      Du liest jede Sekunde die Datei /opt/iobroker/log/iobroker.YYYY-MM-DD.log aus und filterst das, wie du es willst.

                                      Danach in eine Variable (z.B. javascript.0.log) raus schreiben.

                                      Obwohl man doch direkt in diese Variable raus schreiben konnte. Einfach ein Global Skript anlegen:

                                      createState('log', '');
                                      function toLog(text) {
                                          console.log(text);
                                          var lines = getState('log').val;
                                          lines = lines.split('\n');
                                          lines.push(text);
                                          if (lines.length > 25) lines.splice(0,1);
                                          setState('log', lines.join('\n'), true);
                                      }
                                      
                                      

                                      Und dann überall statt log dann toLog benutzen. `

                                      Guten Morgen zusammen!

                                      Ich würde auch gerne mir mein Log in Vis anzeigen lassen aber ich steig da irgendwie nicht durch mit dem was Bluefox da meint!

                                      Ich meine wie filtere ich dann da was raus?

                                      Und was meint Bluefox mit log tolog?

                                      Kann mir da vielleicht jemand helfen?

                                      Johnny `

                                      Bluefox hat hier eine Funktion geschrieben, die den log Befehl ersetzt. Dieses Skript als globales Skript im Javascript Editor abspeichern. Dann über da, wo log-Ausgaben deiner Skripte in VIS erscheinen sollen, statt "log" "toLog" schreiben. Log Ausgaben der Adapter oder Systemfehler oä werden aber nicht berücksichtigt.

                                      createState('log', '');  // Objekt anlegen, dass in VIS als Text dargestellt wird. Hier sind die Logs drin
                                      function toLog(text) { // Funktion toLog ersetzt log
                                          console.log(text);  // normale log-Ausgabe in Konsole (wie immer)
                                          var lines = getState('log').val;  // derzeitigen Inhalt des Objektes abrufen
                                          lines = lines.split('\n'); // zeilenweise aufteilen
                                          lines.push(text); // neue Logzeile anfügen
                                          if (lines.length > 25) lines.splice(0,1);  // wenn mehr als 25 Zeilen da sind, die erste (älteste) löschen
                                          setState('log', lines.join('\n'), true); // und schließlich alles wieder ins Objekt schreiben
                                      }
                                      
                                      

                                      Nochmal: Das ersetzt nicht die Anzeige von Fehler der Adapter. Man kann sich aber so eine ziemlich Variable Ereignis Liste bauen.

                                      Gruß

                                      Pix

                                      1 Reply Last reply Reply Quote 0
                                      • S
                                        Smartuser last edited by

                                        @Bluefox:

                                        @blauholsten:

                                        //***************GLOBALES_SCRIPT*********************
                                        createState('log', '');
                                        
                                        function getTimeAsString(d) {
                                            var date = d || new Date();
                                            return date.getFullYear() + '.' + ('0' + (date.getMonth() + 1)).slice(-2) + '.' + ('0' + date.getDate()).slice(-2) + ' '+
                                         ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2) + ':' +  ('0' + date.getSeconds()).slice(-2);    
                                        }
                                        function toLog(text, addTimestamp) 
                                        {
                                            console.log(text);
                                            var lines = getState('log').val;
                                            lines = lines.split('
                                        ');
                                            if (addTimestamp) {
                                                    lines.push(getTimeAsString() + ': ' + text);
                                            } else {
                                                    lines.push(text);
                                            }
                                            if (lines.length > 25) lines.splice(0,1);
                                            setState('log', lines.join('
                                        '), true);
                                        }
                                        
                                        

                                        Und dann, immer wenn Zeitstempel da sein muss:

                                        toLog('mit zeitstempel', true);
                                        toLog('ohne zeitstempel');
                                        ```` `  `  
                                        

                                        Hallo Zusammen,

                                        ich nutze seit einiger Zeit dieses Script.

                                        Es funktioniert auch alles.

                                        Allerdings hätte ich gern das neue Meldungen immer oben im Log stehen und nicht unten an die letzte Zeile angefügt werden.

                                        Kann mir jemand sagen wie ich das Script dahingehend ändern muss? Geht das überhaupt so einfach?

                                        Gruß

                                        1 Reply Last reply Reply Quote 0
                                        • blauholsten
                                          blauholsten Developer last edited by

                                          @Smartuser:

                                          Hallo Zusammen,

                                          ich nutze seit einiger Zeit dieses Script.

                                          Es funktioniert auch alles.

                                          Allerdings hätte ich gern das neue Meldungen immer oben im Log stehen und nicht unten an die letzte Zeile angefügt werden.

                                          Kann mir jemand sagen wie ich das Script dahingehend ändern muss? Geht das überhaupt so einfach?

                                          Gruß `

                                          //***************GLOBALES_SCRIPT*********************
                                          createState('log', '');
                                          
                                          function getTimeAsString(d) {
                                              var date = d || new Date();
                                              return date.getFullYear() + '.' + ('0' + (date.getMonth() + 1)).slice(-2) + '.' + ('0' + date.getDate()).slice(-2) + ' '+
                                           ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2) + ':' +  ('0' + date.getSeconds()).slice(-2);    
                                          }
                                          function toLog(text, addTimestamp) 
                                          {
                                              console.log(text);
                                              var lines = getState('log').val;
                                              lines = lines.split('
                                          ');
                                              if (addTimestamp) {
                                                      lines.unshift(getTimeAsString() + ': ' + text);
                                              } else {
                                                      lines.unshift(text);
                                              }
                                              if (lines.length > 25) lines.splice(0,1);
                                              setState('log', lines.join('
                                          '), true);
                                          }
                                          

                                          So sollte es gehen

                                          1 Reply Last reply Reply Quote 0
                                          • S
                                            Smartuser last edited by

                                            @blauholsten:

                                            So sollte es gehen `
                                            Perfekt … funktioniert!

                                            Vielen Dank für die mega schnelle Hilfe! 😄

                                            Gruß

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            880
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            11
                                            34
                                            9293
                                            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