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. [GELOEST]Log Daten im VIS anzeigen

NEWS

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

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

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.2k

[GELOEST]Log Daten im VIS anzeigen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
34 Beiträge 11 Kommentatoren 10.4k Aufrufe 4 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.
  • blauholstenB Offline
    blauholstenB Offline
    blauholsten
    Developer
    schrieb am zuletzt editiert von
    #1

    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.

    Entwickler vom: - Viessman Adapter
    - Alarm Adapter

    1 Antwort Letzte Antwort
    0
    • BluefoxB Offline
      BluefoxB Offline
      Bluefox
      schrieb am zuletzt editiert von
      #2

      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 Antwort Letzte Antwort
      0
      • blauholstenB Offline
        blauholstenB Offline
        blauholsten
        Developer
        schrieb am zuletzt editiert von
        #3

        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

        Entwickler vom: - Viessman Adapter
        - Alarm Adapter

        1 Antwort Letzte Antwort
        0
        • BluefoxB Offline
          BluefoxB Offline
          Bluefox
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          0
          • blauholstenB Offline
            blauholstenB Offline
            blauholsten
            Developer
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            0
            • BluefoxB Offline
              BluefoxB Offline
              Bluefox
              schrieb am zuletzt editiert von
              #6

              In welchem Widget zeigst du es an?

              1 Antwort Letzte Antwort
              0
              • blauholstenB Offline
                blauholstenB Offline
                blauholsten
                Developer
                schrieb am zuletzt editiert von
                #7

                @Bluefox:

                In welchem Widget zeigst du es an? `
                Basic string

                Entwickler vom: - Viessman Adapter
                - Alarm Adapter

                1 Antwort Letzte Antwort
                0
                • BluefoxB Offline
                  BluefoxB Offline
                  Bluefox
                  schrieb am zuletzt editiert von
                  #8

                  @blauholsten:

                  @Bluefox:

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

                  1 Antwort Letzte Antwort
                  0
                  • P Offline
                    P Offline
                    pix
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    0
                    • blauholstenB Offline
                      blauholstenB Offline
                      blauholsten
                      Developer
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      0
                      • blauholstenB Offline
                        blauholstenB Offline
                        blauholsten
                        Developer
                        schrieb am zuletzt editiert von
                        #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 Antwort Letzte Antwort
                        0
                        • BluefoxB Offline
                          BluefoxB Offline
                          Bluefox
                          schrieb am zuletzt editiert von
                          #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 Antwort Letzte Antwort
                          0
                          • blauholstenB Offline
                            blauholstenB Offline
                            blauholsten
                            Developer
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            0
                            • BluefoxB Offline
                              BluefoxB Offline
                              Bluefox
                              schrieb am zuletzt editiert von
                              #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 Antwort Letzte Antwort
                              0
                              • blauholstenB Offline
                                blauholstenB Offline
                                blauholsten
                                Developer
                                schrieb am zuletzt editiert von
                                #15

                                @bluefox:

                                Perfekt DANKE

                                Entwickler vom: - Viessman Adapter
                                - Alarm Adapter

                                1 Antwort Letzte Antwort
                                0
                                • P Offline
                                  P Offline
                                  PrinzEisenherz1
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  0
                                  • P Offline
                                    P Offline
                                    pix
                                    schrieb am zuletzt editiert von
                                    #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 Antwort Letzte Antwort
                                    0
                                    • S Offline
                                      S Offline
                                      Smartuser
                                      schrieb am zuletzt editiert von
                                      #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 Antwort Letzte Antwort
                                      0
                                      • blauholstenB Offline
                                        blauholstenB Offline
                                        blauholsten
                                        Developer
                                        schrieb am zuletzt editiert von
                                        #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 Antwort Letzte Antwort
                                        0
                                        • S Offline
                                          S Offline
                                          Smartuser
                                          schrieb am zuletzt editiert von
                                          #20

                                          @blauholsten:

                                          So sollte es gehen `
                                          Perfekt … funktioniert!

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

                                          Gruß

                                          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

                                          613

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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