NEWS
[gelöst] Problem mit fs.readFile()
-
Hallo zusammen,
habe ein kleines Problem bei dem ich seit zwei Stunden nicht weiterkomme:
Ich möchte den Text aus einer Datei in einem script verarbeiten. Genauer gesagt aus einer log-Datei von iobroker.
Folgenden Code habe ich dazu verwendet:
var data, today, position, meldung; function Log_Datei_auslesen() { var fs = require('fs'); fs.readFile(today, 'utf8', function (error, data) { if(error) log('Fehler beim Lesen von ' + today, 'error'); else log(data); }); } today = ['/opt/iobroker/log/iobroker.',('' + (new Date().getFullYear())),'-',('' + formatDate(new Date(), "MM")),'-',('' + formatDate(new Date(), "TT")),'.log'].join(''); Log_Datei_auslesen(); console.log(data); position = data.indexOf('alexa2.0') + 1; meldung = data.slice((position - 1), position + 50);Den Code zum auslesen der Datei habe ich hier aus dem Forum. Mit dem Befehl [log(data)] (innerhalb der Funktion) wird der Inhalt der Variablen "data" auch korrekt und vollständig im Log ausgegeben.
Nur im weiteren Verlauf des scripts kann ich mit der Variable "data" nicht weiterarbeiten. Der spätere Befehl [console.log(data)] (außerhalb der Funktion) gibt als Ergebnis immer nur "undefined" aus. (wobei ich mir nicht sicher bin was genau der Unterschied zu "log" und "console.log" ist…)
Es scheint so, als ob die Variable "data" nach dem Ausführen der Funktion wieder geleert wird. Nur ich weiß nicht wieso...
Sieht jemand den Fehler?
-
fs.readFile() arbeitet asynchron, d.h. die Auswertung von data muss innerhalb der Callback-Funktion erfolgen. Als Alternative gibt es auch https://code-maven.com/reading-a-file-with-nodejs.
-
OK, das hätte ich wahrscheinlich nie rausbekommen…
Vielen lieben Dank!!! Mit fs.readFileSync() klappt es nun ganz hervorragend.
Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.
Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.
Mit deinem Input könnte dieser Beitrag noch besser werden 💗
Registrieren Anmelden