Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. [GELOEST]Log Daten im VIS anzeigen

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    13
    1
    147

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    4.3k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.3k

[GELOEST]Log Daten im VIS anzeigen

Scheduled Pinned Locked Moved Skripten / Logik
34 Posts 11 Posters 10.7k Views 4 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • BluefoxB Offline
    BluefoxB Offline
    Bluefox
    wrote on last edited by
    #4
    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
    0
    • blauholstenB Offline
      blauholstenB Offline
      blauholsten
      Developer
      wrote on last edited by
      #5

      @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

      Entwickler vom: - Viessman Adapter
      - Alarm Adapter

      1 Reply Last reply
      0
      • BluefoxB Offline
        BluefoxB Offline
        Bluefox
        wrote on last edited by
        #6

        In welchem Widget zeigst du es an?

        1 Reply Last reply
        0
        • blauholstenB Offline
          blauholstenB Offline
          blauholsten
          Developer
          wrote on last edited by
          #7

          @Bluefox:

          In welchem Widget zeigst du es an? `
          Basic string

          Entwickler vom: - Viessman Adapter
          - Alarm Adapter

          1 Reply Last reply
          0
          • BluefoxB Offline
            BluefoxB Offline
            Bluefox
            wrote on last edited by
            #8

            @blauholsten:

            @Bluefox:

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

            1 Reply Last reply
            0
            • P Offline
              P Offline
              pix
              wrote on last edited by
              #9

              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

              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 Reply Last reply
              0
              • blauholstenB Offline
                blauholstenB Offline
                blauholsten
                Developer
                wrote on last edited by
                #10

                @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)

                Entwickler vom: - Viessman Adapter
                - Alarm Adapter

                1 Reply Last reply
                0
                • blauholstenB Offline
                  blauholstenB Offline
                  blauholsten
                  Developer
                  wrote on last edited by
                  #11

                  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

                  Entwickler vom: - Viessman Adapter
                  - Alarm Adapter

                  1 Reply Last reply
                  0
                  • BluefoxB Offline
                    BluefoxB Offline
                    Bluefox
                    wrote on last edited by
                    #12

                    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
                    0
                    • blauholstenB Offline
                      blauholstenB Offline
                      blauholsten
                      Developer
                      wrote on last edited by
                      #13

                      @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);
                      }
                      
                      

                      Entwickler vom: - Viessman Adapter
                      - Alarm Adapter

                      1 Reply Last reply
                      0
                      • BluefoxB Offline
                        BluefoxB Offline
                        Bluefox
                        wrote on last edited by
                        #14

                        @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
                        0
                        • blauholstenB Offline
                          blauholstenB Offline
                          blauholsten
                          Developer
                          wrote on last edited by
                          #15

                          @bluefox:

                          Perfekt DANKE

                          Entwickler vom: - Viessman Adapter
                          - Alarm Adapter

                          1 Reply Last reply
                          0
                          • P Offline
                            P Offline
                            PrinzEisenherz1
                            wrote on last edited by
                            #16

                            @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

                            Intel-NUC mit ProxMox: ioBroker,SQL, logging Strom- Gas- u. Wasserzähler;10Zoll Tab im Flur für VIS; weiteres: Homematic CCU2, Homeduino, Kameras, selbstgebaute Wetterstation;

                            1 Reply Last reply
                            0
                            • P Offline
                              P Offline
                              pix
                              wrote on last edited by
                              #17

                              @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

                              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 Reply Last reply
                              0
                              • S Offline
                                S Offline
                                Smartuser
                                wrote on last edited by
                                #18

                                @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
                                0
                                • blauholstenB Offline
                                  blauholstenB Offline
                                  blauholsten
                                  Developer
                                  wrote on last edited by
                                  #19

                                  @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

                                  Entwickler vom: - Viessman Adapter
                                  - Alarm Adapter

                                  1 Reply Last reply
                                  0
                                  • S Offline
                                    S Offline
                                    Smartuser
                                    wrote on last edited by
                                    #20

                                    @blauholsten:

                                    So sollte es gehen `
                                    Perfekt … funktioniert!

                                    Vielen Dank für die mega schnelle Hilfe! :D

                                    Gruß

                                    1 Reply Last reply
                                    0
                                    • S Offline
                                      S Offline
                                      Smartuser
                                      wrote on last edited by
                                      #21

                                      Hi,

                                      ich habe doch noch ein paar Fragen zu dem Script. :)

                                      Aktuell wir dieser "log" in den Objekten direkt unter "javascript.0" erstellt. Wie muss ich denn das Script abändern, damit dieser in einem "Unterordner" angelegt wird?

                                      Aktuell stopt das "Füllen" des "log" bei einer Zeilenanzahl von 25. Danach kommen keine neuen Einträge mehr dazu.

                                      Ich gehe davon aus, dass diese Zeile dafür verantwortlich ist:

                                      if (lines.length > 25) lines.splice(0,1);
                                      

                                      Wenn ich diesen Wert erhöhe, werden auch mehr Einträge geschrieben.

                                      Ist das ein Fehler in dem Script und die Code-Zeile soll eigentlich einen Zeilenumbruch bewirken?

                                      Oder ist das gewollt das nicht mehr als 25 Zeilen geschrieben werden sollen? Was wiederum die Frage aufwirft … gibt es irgendwie ein Problem, wenn man sei ein "Object" mit sehr vielen Zeichen/Zeilen füllt?

                                      Gruß ...

                                      1 Reply Last reply
                                      0
                                      • S Offline
                                        S Offline
                                        Smartuser
                                        wrote on last edited by
                                        #22

                                        ich push nochmal ;)

                                        Gruß

                                        1 Reply Last reply
                                        0
                                        • wendy2702W Offline
                                          wendy2702W Offline
                                          wendy2702
                                          wrote on last edited by
                                          #23

                                          @Smartuser:

                                          ich push nochmal ;)

                                          Gruß `

                                          Machst besser ein neues Thema auf.

                                          Durch das [Gelöst] im Titel hat das Thema weniger Aufmerksamkeit!

                                          Bitte keine Fragen per PN, die gehören ins Forum!

                                          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          419

                                          Online

                                          32.7k

                                          Users

                                          82.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe