Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [gelöst] Problem mit fs.readFile()

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] Problem mit fs.readFile()

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

      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?

      1 Reply Last reply Reply Quote -1
      • paul53
        paul53 last edited by

        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.

        1 Reply Last reply Reply Quote 0
        • N
          nathan1312 last edited by

          OK, das hätte ich wahrscheinlich nie rausbekommen…

          Vielen lieben Dank!!! Mit fs.readFileSync() klappt es nun ganz hervorragend.

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

          Support us

          ioBroker
          Community Adapters
          Donate

          818
          Online

          31.8k
          Users

          79.9k
          Topics

          1.3m
          Posts

          2
          3
          1100
          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