NEWS
[GELOEST]Log Daten im VIS anzeigen
-
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.
-
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??)
-
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); }
-
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….
-
In welchem Widget zeigst du es an?
-
In welchem Widget zeigst du es an? `
Basic string -
In welchem Widget zeigst du es an?
Basic string
Nimm "basic-string unescaped" -
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
-
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.
In welchem Widget zeigst du es an?
Basic string
Nimm "basic-string unescaped" `Das haut wunderbar hin!!! (aber erst nach der Veränderung)
-
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
-
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')));
-
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); }
-
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');
-
Perfekt DANKE
-
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
-
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
-
//***************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ß
-
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
-
So sollte es gehen `
Perfekt … funktioniert!Vielen Dank für die mega schnelle Hilfe!
Gruß
-
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ß ...