Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. [gelöst] Adapter - Parser / Wartezeiten auslesen

    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] Adapter - Parser / Wartezeiten auslesen

    This topic has been deleted. Only users with topic management privileges can see it.
    • Glasfaser
      Glasfaser @Homoran last edited by Glasfaser

      @Homoran

      Meinst du das :

      
      var pfad            = "Systeminfos.ioBroker.Prozesse" + "."; // Pfad in dem die Datenpunkte angelegt werden
      
      // Datenpunktnamen:
      var idProzesse          = pfad + 'ioBroker_Prozesse';
      var idMemAll            = pfad + 'ioBroker_Speicher_gesamt';
      var idAnzProzesse       = pfad + 'ioBroker_Anzahl_Prozesse';
      var idCpuAll            = pfad + 'ioBroker_CPU_Gesamt';
      var idMemPercent        = pfad + 'ioBroker_Speicher_prozentual';
      var idInstanzenEinmal   = pfad + 'ioBroker_Instanzen_einmal_aktiv';
      
      
      // regelmässige Wiederholungen der Abfrage
      var cronStr         = "*/2 * * * *";
      
      var abfrage         = 'ps -A aux --sort -pmem | grep " [i]o.*"';
      
      
      
      
      // -----------------------------------------------------------------------------
      
      
      createState(idProzesse, "", {
          name: 'ioBroker laufende Prozesse Objekt',
          desc: 'ioBroker laufende Prozesse Objekt, Speicherverbrauch',
          type: 'string',
          unit: '',
          role: 'object'
      });
      
      createState(idMemAll, 0, {
          name: 'ioBroker Speicherverbrauch gesamt',
          desc: 'ioBroker Speicherverbrauch gesamt (RSS)',
          type: 'number',
          unit: 'MB',
          role: 'value'
      });
      
      createState(idAnzProzesse, 0, {
          name: 'ioBroker Anzahl Prozesse',
          desc: 'ioBroker Anzahl aktiver Prozesse',
          type: 'number',
          unit: '',
          role: 'value'
      });
      
      createState(idCpuAll, 0.0, {
          name: 'ioBroker CPU-Last gesamt',
          desc: 'ioBroker CPU-Last gesamt',
          type: 'number',
          unit: '%',
          role: 'value'
      });
      
      createState(idMemPercent, 0.0, {
          name: 'Speicherverbrauch prozentual',
          desc: 'Speicherverbrauch prozentual',
          type: 'number',
          unit: '%',
          role: 'value'
      });
      
      createState(idInstanzenEinmal, true, {
          name: 'keine Instanzen doppelt aktiv',
          desc: 'jeder aktive ioBroker Prozess ist nur einmal aktiv',
          type: 'boolean',
          unit: '',
          role: 'value'
      });
      
      
      
      // -----------------------------------------------------------------------------
      
      
      function doppelteProzesse(arr) {
         var mehrfacheProzesse = [];
         var anzProzesse = (arr.length);
         var anzProzessAktiv = 0;
         for (var i = 0; i < anzProzesse; i++) {
             if (mehrfacheProzesse.indexOf(arr[i].command) == -1) {
                 anzProzessAktiv = zaehleProzesse(arr,arr[i].command);
                 if (anzProzessAktiv > 1) {
                     log("Prozess: " + arr[i].command+", mehrfach aktiv: " + anzProzessAktiv +" mal","warn");
                     mehrfacheProzesse.push(arr[i].command);
                     mehrfacheProzesse.push(anzProzessAktiv);
                 }
             }
         }    
         return mehrfacheProzesse;
      }
      
      function zaehleProzesse(arr,command) {
         var count = 0;
         var anzProzesse = (arr.length);
         for (var i = 0; i < anzProzesse; i++) {
             if(arr[i].command === command) {
                 count++;
             }
         }    
         return count;
      }
      
      
      function writeJson(json) {
         return JSON.stringify(json);    // JSON in String umwandeln, damit das JSON in einem Datenpunkt geschrieben werden kann
      }
      
      
      function getMemAbsolut(json) {
         var anzProzesse = (json.length);
         var mem = 0;
         for (var i = 0; i < anzProzesse; i++) {
             mem = mem + json[i].rss;
         }    
         return mem;
      }
      
      function getCpu(json) {
         var anzProzesse = (json.length);
         var cpu = 0.0;
         for (var i = 0; i < anzProzesse; i++) {
             cpu = cpu + json[i].cpu;
         }    
         return cpu;
      }
      
      function getMem(json) {
         var anzProzesse = (json.length);
         var mem = 0.0;
         for (var i = 0; i < anzProzesse; i++) {
             mem = mem + json[i].mem;
         }    
         return mem;
      }
      
      
      function createArrayJson(arr) {
         var jsonArr     = [];
         var anzDP       = 11;                       // Anzahl Datenreihen in der Abfrage
         var anzProzesse = (arr.length-1)/anzDP;
      
         for (var i = 0; i < anzProzesse; i++) {
             jsonArr.push({
                 command:    arr[10 + i*anzDP],              // ioBroker Prozess (COMMAND = Kommando, mit dem der Prozess gestartet wurde)
                 pid:        arr[ 1 + i*anzDP],              // Prozess ID
                 cpu:        parseFloat(arr[ 2 + i*anzDP]),  // aktueller CPU-Last in %
                 mem:        parseFloat(arr[ 3 + i*anzDP]),  // aktueller Verbrauch physikalischer Speicher %
                 vmem:       parseInt(arr[ 4 + i*anzDP]),    // 
                 rss:        parseInt(arr[ 5 + i*anzDP]),    // physikalische Speichernutzung
                 start:      arr[ 8 + i*anzDP],              // Startzeitpunkt des Prozesses
                 time:       arr[ 9 + i*anzDP]               // bisher verbrauchte CPU Zeit
             });
         }
         return jsonArr;
      }
      
      
      function abfrageConsole() {
         exec(abfrage, function(err, stdout, stderr) {
             if (err) {
                 log(err,"error");
                 return;
             }
             stdout = stdout.replace(/\n+/g, " "); // neue Zeile gegen Leerzeichen ersetzen
             stdout = stdout.split(/ +/g);         // array erstellen, Lerzeichen als Trenner
             
             var anzProzesse = (stdout.length-1) / 11;
             
             //log(stdout);
             //log("Anzahl laufender ioBroker Prozesse: " + anzProzesse);
             
             var jsonArr = createArrayJson(stdout);
             var mem         = Math.floor(getMemAbsolut(jsonArr)/1024);
             var cpu         = Math.floor(getCpu(jsonArr)*10)/10;
             var memPercent  = Math.floor(getMem(jsonArr)*10)/10;
      
             var doppeltArr = doppelteProzesse(jsonArr);
             
             if(doppeltArr.length === 0) {
                 setState(idInstanzenEinmal, "✅" );
             } else {
                 setState(idInstanzenEinmal, "❌" );
             }
             
              
             setState(idProzesse     ,writeJson(jsonArr));
             setState(idMemAll       ,mem);
             setState(idAnzProzesse  ,anzProzesse);
             setState(idCpuAll       ,cpu);
             setState(idMemPercent   ,memPercent);
         });
      }
      
      
      function abfragen() {
         abfrageConsole();
      }
      
      // regelmässige Wiederholungen
      // -----------------------------------------------------------------------------
      schedule(cronStr, abfragen);
      
      
      // main
      // -----------------------------------------------------------------------------
      function main() {
         abfragen();
      }
      
      
      // Start Skript:
      // -----------------------------------------------------------------------------
      
      setTimeout(main,    500);
      
      
      
      

      …...
      Dieses habe ich Ihm vorgeschlagen :

      ID oder Name eines State in Vis anzeigen

      Homoran 1 Reply Last reply Reply Quote 0
      • Homoran
        Homoran Global Moderator Administrators @Glasfaser last edited by Homoran

        @Glasfaser
        Ja!

        und ich habe damals irgendwas geändert, damit die Tabell nicht nach mem sondern nach cpu sortiert wurde.
        json_table.png

        Das kommt davon wenn man davon nix versteht und trotzdem bastelt 😞

        EDIT.
        Habe es gefunden - war im Skript, nicht im widget 😞

        var abfrage         = 'ps -A aux --sort -pcpu | grep " [i]o.*"';
        
        1 Reply Last reply Reply Quote 0
        • A
          Alexxx2005 last edited by Alexxx2005

          Also mit :

          var cacheSelector = $('state[id=parser.0.*]');

          var htmlString ="<table><tr><td>NAME   </td><td>IP   </td><td>   </td></tr>";

          var cacheSelector = $('[id=parser.0.*]');

          //console.log(cacheSelector);

          var counter =0;

          cacheSelector.each(function(id, i) {

          counter = counter+1

          var devicename = getObject(id).common.name;

          var ip = id.replace(/_/g, ".");

          var ip = ip.replace(/parser.0./g, "");

          // log(id + " : " + devicename + " : " + ip );

          var devicenameName=devicename;

          devicename="Netzwerk.Gerät"+counter.toString()+".NameGerät";

          createState(devicename, 'empty', { name: 'Name des Geräts', desc: '', type: 'string', role: '',read: true, write: true });

          setStateDelayed(devicename, devicenameName, 800);

          devicename="Netzwerk.Gerät"+counter.toString()+".IPAdresse";

          setStateDelayed(devicename, ip, 800);

          createState(devicename, 'empty', { name: 'IP des Geräts', desc: '', type: 'string', role: '',read: true, write: true });

          var wert1 = getState(id).val;

          if (wert1) wert1 = "✅";

          if (!wert1) wert1= "❌";

          htmlString=htmlString.concat("<tr><td>" + devicenameName + "   </td><td>" + ip + "   </td><td>" + wert1 + "</td></tr>");

          });

          //log(counter);

          createState('Netzwerk.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });

          createState('Netzwerk.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });

          setStateDelayed('Netzwerk.Anzahl', counter, 800);

          setStateDelayed('Netzwerk.StringHTML', htmlString.concat("</table>"), 800);

          bekomme ich mal eine Ladung Netzwerk Geräte mit den Namen der Bahnen

          NetzwerkGeräte.PNG

          das ist schon mal ok in dem String HTML kommt auch die Ausgabe

          StringHtml.PNG

          Im Prinzip bräuchte ich ein Ordner und im String HTML sollte Bahn , Wartezeit
          stehen (das würde ich noch hinbekommen)

          Aber Absteigende Sortierung und Grüner Pfeil für geöffnet (ab 1Minute aufwärts)
          oder ein rotes Kreuz bei Ausgabe "Null Minuten" (für geschlossen) sowas checke ich nicht,
          da kann nur @liv-in-sky helfen.

          Achja , der parser.0 zeigt die Bahnen wie folgt an :

          Parser0.PNG

          Grüße Alex

          liv-in-sky 1 Reply Last reply Reply Quote 0
          • liv-in-sky
            liv-in-sky @Alexxx2005 last edited by liv-in-sky

            @Alexxx2005

            hab es nur überflogen - bin zeitlich etwas eng - vielleicht hilft das weiter

            probier mal das hier - es wird alle 30 sekunden gecheckt und dann ausgegeben

            mit sortierung

            test2.gif

            var cacheSelector = $('state[id=parser.0.*]');
            
            
            
            var cacheSelector = $('[id=parser.0.*]');
            
            
            schedule( "*/30 * * * * *",  function () {   
             
            var sortArr=[];
            var htmlString ="<table><tr><td>NAME   </td><td>IP   </td><td>   </td></tr>";
            
            //console.log(cacheSelector);
            
            
            
            var counter =0;
            
            cacheSelector.each(function(id, i) {
            
            counter = counter+1
            
            var devicename = getObject(id).common.name;
            
            var ip = id.replace(/_/g, ".");
            
            var ip = ip.replace(/parser.0./g, "");
            
            // log(id + " : " + devicename + " : " + ip );
            
            var devicenameName=devicename;
            
            devicename="Netzwerk.Gerät"+counter.toString()+".NameGerät";
            
            createState(devicename, 'empty', { name: 'Name des Geräts', desc: '', type: 'string', role: '',read: true, write: true });
            
            setStateDelayed(devicename, devicenameName, 800);
            
            
            devicename="Netzwerk.Gerät"+counter.toString()+".IPAdresse";
            
            setStateDelayed(devicename, ip, 800);
            
            createState(devicename, 'empty', { name: 'IP des Geräts', desc: '', type: 'string', role: '',read: true, write: true });
            
            var wert1 = getState(id).val;
            var wert0 = getState(id).val;
            
            if (wert1) wert1 = "✅";
            
            if (!wert1) wert1= "❌";
            
            let help = [devicename,ip,wert0,wert1];
            sortArr.push(help);
            //log(sortArr[0]);
            
            });
            
            function numSort(a, b) { 
               
              return parseInt(a[2]) - parseInt(b[2]);
            } 
            
            sortArr.sort(numSort);
                     
            
            
            
                   for (var i=0; i<sortArr.length;i++) {
                       htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] + "   </td><td>" + sortArr[i][3] + "</td></tr>";
                   }      
            
            //htmlString=htmlString.concat("<tr><td>" + devicenameName + "   </td><td>" + ip + "   </td><td>" + wert1 + "</td></tr>");
            
            //log(counter);
            
            createState('Netzwerk.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
            
            createState('Netzwerk.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
            
            setStateDelayed('Netzwerk.Anzahl', counter, 800);
            setStateDelayed('Netzwerk.StringHTML', htmlString.concat("</table>"), 800);
            });
            
            

            1 Reply Last reply Reply Quote 1
            • A
              Alexxx2005 last edited by Alexxx2005

              @liv-in-sky

              Jawohl das sieht schon mal gut aus, habe soweit mal alles angepasst was ich
              machen konnte


              var cacheSelector = $('state[id=parser.0.]');
              var cacheSelector = $('[id=parser.0.
              ]');
              schedule( "*/30 * * * * *", function () {
              var sortArr=[];
              var htmlString ="<table><tr><td>Bahn </td><td>Wartezeit in Minuten </td><td> </td></tr>";
              //console.log(cacheSelector);
              var counter =0;
              cacheSelector.each(function(id, i) {
              counter = counter+1
              var devicename = getObject(id).common.name;
              var ip = id.replace(/_/g, ".");
              var ip = ip.replace(/parser.0./g, "");
              // log(id + " : " + devicename + " : " + ip );
              var devicenameName=devicename;
              devicename="Park.Wartezeit"+counter.toString()+".Bahn";
              createState(devicename, 'empty', { name: 'Name der Bahn', desc: '', type: 'string', role: '',read: true, write: true });
              setStateDelayed(devicename, devicenameName, 800);
              devicename="Park.Wartezeit"+counter.toString()+".Bahn";
              setStateDelayed(devicename, ip, 800);
              createState(devicename, 'empty', { name: 'Bahn', desc: '', type: 'string', role: '',read: true, write: true });
              var wert1 = getState(id).val;
              var wert0 = getState(id).val;
              if (wert1) wert1 = "✅";
              if (!wert1) wert1= "❌";
              let help = [devicename,ip,wert0,wert1];
              sortArr.push(help);
              //log(sortArr[0]);
              });
              function numSort(a, b) {

              return parseInt(a[2]) - parseInt(b[2]);

              }

              sortArr.sort(numSort);

                 for (var i=0; i<sortArr.length;i++) {
              
                     htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] + "   </td><td>" + sortArr[i][3] + "</td></tr>";
              
                 }      
              

              //htmlString=htmlString.concat("<tr><td>" + devicenameName + " </td><td>" + ip + " </td><td>" + wert1 + "</td></tr>");
              //log(counter);
              createState('Park.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
              createState('Park.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
              setStateDelayed('Park.Anzahl', counter, 800);
              setStateDelayed('Park.StringHTML', htmlString.concat("</table>"), 800);
              });

              Das Ergebniss :

              angepasst.PNG

              wenn ich nun bei :

              let help = [devicename,ip,wert0,wert1];
              

              den devicename, lösche erhalte ich diese Ausgabe :

              soll.PNG

              das würde meiner Vorstellung entsprechen, allerdings passt nun
              die Sortierung nicht mehr und nach dem Haken kommt ein
              "undefined"

              Leider verstehe ich nicht warum das jetzt kommt bzw. was ich noch
              löschen muss damit es nicht mehr kommt.

              Und was müßte man noch ändern für eine "absteigende Sortierung"

              Danke,

              Grüße Alex

              liv-in-sky 1 Reply Last reply Reply Quote 0
              • liv-in-sky
                liv-in-sky @Alexxx2005 last edited by liv-in-sky

                @Alexxx2005

                hier wird sotiert - wenn du die werte im array änderst kommt es zu problemen

                function numSort(a, b) { 
                    
                   return parseInt(a[2]) - parseInt(b[2]);
                } 
                
                sortArr.sort(numSort);
                

                hier wird das array geschrieben:

                let help = [devicename,ip,wert0,wert1];
                

                devicename = 0, ip =1, wert0 =2 wert1=3

                in der sortierung wird auf wert [2] sortiert - das hat sich ja geändert, weil du etwas nicht mehr ins array schreibst - wenn der devicename fehlt, ist ip =0, wert0 = 1 und wert1=2 --> du musst die 2 auf die 1 ändern in der sortierung

                bei der ausgabe: es fehlt auch da der devicename also musst du auch dort den punktsortArr[i][3] löschen, da der nicht mehr existiert (undefined) - das array geht nur von 0 bis 2 (3 werte) nicht von 0 bis 3 (4 werte)

                   htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] +  "</td></tr>";
                

                die sortierung umdrehen: versuch mal

                function numSort(a, b) { 
                    
                   return   parseInt(b[2]) - parseInt(a[2]);
                } 
                

                also b[2] und a[2] austauschen - bzw. steht da ja jetzt b[1]-a[1], da wir das oben umgestellt haben

                1 Reply Last reply Reply Quote 0
                • A
                  Alexxx2005 last edited by

                  Danke sehr gut erklärt, nun habe ich es verstanden, hätte jetzt noch zwei Fragen :

                  Kreuze.PNG

                  jede Bahn die nicht im Betrieb ist wird mit "null" und "X" ausgegeben,

                  Ist es möglich das dies in der Liste ganz unten oder ganz oben ausgegeben wird.
                  Ebenfalls würde mich noch interessieren ob es möglich ist die Tabelle :

                  zweizeilig.png

                  zwei Spaltig zu gespalten damit die Zeilen nicht zu lang werden und es ins VIS geht 🙂

                  Grüße Alex

                  liv-in-sky 2 Replies Last reply Reply Quote 0
                  • liv-in-sky
                    liv-in-sky @Alexxx2005 last edited by

                    @Alexxx2005 das null ist irgendwie falsch - da müßte 0 stehen - dann würde es auch sortiert werden

                    paste mal dein momentanes script

                    Homoran 1 Reply Last reply Reply Quote 0
                    • liv-in-sky
                      liv-in-sky @Alexxx2005 last edited by

                      @Alexxx2005 und zeige mal, was in den parser.0 datenpunkten steht - ist da schon de fehler vom parsen ? "null" ist ein "fehler" und bedeutet nicht 0

                      den müßte man dann noch abfangen im script

                      A 1 Reply Last reply Reply Quote 0
                      • Homoran
                        Homoran Global Moderator Administrators @liv-in-sky last edited by

                        @liv-in-sky sagte in Adapter - Parser soll Wartezeiten auslesen:

                        da müßte 0 stehen

                        unendlich wäre sinnvoller 😉

                        liv-in-sky 1 Reply Last reply Reply Quote 0
                        • liv-in-sky
                          liv-in-sky @Homoran last edited by

                          @Homoran unendlich oder "not available"

                          Homoran 1 Reply Last reply Reply Quote 0
                          • Homoran
                            Homoran Global Moderator Administrators @liv-in-sky last edited by

                            @liv-in-sky
                            Wenn es in Zahlen ausgedrückt werden soll ist bei geschlossen die Wartezeit unendlich oder pragmatich 999(9999) je nach anzahl der Stellen

                            liv-in-sky 1 Reply Last reply Reply Quote 0
                            • liv-in-sky
                              liv-in-sky @Homoran last edited by

                              @Homoran jo - da hast du wohl recht

                              1 Reply Last reply Reply Quote 0
                              • A
                                Alexxx2005 @liv-in-sky last edited by Alexxx2005

                                @liv-in-sky

                                parser.PNG

                                Das "Null" steht drin weil die Bahn heute nicht geloggt wird kp.
                                Sie erscheint auch nicht auf der Homepage , wenn ich z.b. einen
                                falschen Link eingebe kommt ebenfalls "Null"

                                Dachte man kann beim parser bei Ersatz eine Ersatzzahl definieren
                                aber das funktioniert nicht.

                                Grüße Alex

                                liv-in-sky 1 Reply Last reply Reply Quote 0
                                • liv-in-sky
                                  liv-in-sky @Alexxx2005 last edited by

                                  @Alexxx2005 soll den eine solche "null"-bahn überhaupt in der tabelle erscheinben oder soll sie mit einem bestimmten wert bzw. bild erscheinen 🔐 oder🔒 oder ⏳ oder r♾️ siehe https://emojipedia.org/objects/

                                  poste noch das script

                                  A 1 Reply Last reply Reply Quote 0
                                  • A
                                    Alexxx2005 @liv-in-sky last edited by Homoran

                                    @liv-in-sky also am besten wäre das Locked Symbol 🔒 wahrscheinlich ist die Bahn dann defekt oder über Winterzeit geschlossen...

                                    var cacheSelector = $('state[id=parser.0.*]');
                                    var cacheSelector = $('[id=parser.0.*]');
                                    schedule( "*/03 * * * * *",  function () {   
                                    var sortArr=[];
                                    var htmlString ="<table><tr><td>Bahn   </td><td>Wartezeit   </td><td>   </td></tr>";
                                    //console.log(cacheSelector);
                                    var counter =0;
                                    cacheSelector.each(function(id, i) {
                                    counter = counter+1
                                    var devicename = getObject(id).common.name;
                                    var ip = id.replace(/_/g, ".");
                                    var ip = ip.replace(/parser.0./g, "");
                                    // log(id + " : " + devicename + " : " + ip );
                                    var devicenameName=devicename;
                                    devicename="Park.Wartezeit"+counter.toString()+".BahnName";
                                    createState(devicename, 'empty', { name: 'Name der Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                    setStateDelayed(devicename, devicenameName, 800);
                                    devicename="Park.Wartezeit"+counter.toString()+".Bahn";
                                    setStateDelayed(devicename, ip, 800);
                                    createState('empty', { name: 'Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                    var wert2 = getState(id).val;
                                    var wert1 = getState(id).val;
                                    if (wert2) wert2 = "✅";
                                    if (!wert2) wert2= "❌";
                                    let help = [ip,wert1,wert2];
                                    sortArr.push(help);
                                    //log(sortArr[0]);
                                    });
                                    function numSort(a, b) { 
                                      return parseInt(b[1]) - parseInt(a[1]);
                                    } 
                                    sortArr.sort(numSort);
                                           for (var i=0; i<sortArr.length;i++) {
                                               htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] +  "</td></tr>";
                                           }      
                                    //htmlString=htmlString.concat("<tr><td>" + devicenameName + "   </td><td>" + ip + "   </td><td>" + wert1 + "</td></tr>");
                                    //log(counter);
                                    createState('Park.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
                                    createState('Park.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
                                    setStateDelayed('Park.Anzahl', counter, 800);
                                    setStateDelayed('Park.StringHTML', htmlString.concat("</table>"), 800);
                                    });
                                    

                                    liv-in-sky 1 Reply Last reply Reply Quote 0
                                    • liv-in-sky
                                      liv-in-sky @Alexxx2005 last edited by liv-in-sky

                                      @Alexxx2005 ich schau mal - bitte poste scripts im code tag

                                      Image 2.png

                                      1 Reply Last reply Reply Quote 0
                                      • A
                                        Alexxx2005 last edited by

                                        Ah so ist's richtig 🙂

                                        var cacheSelector = $('state[id=parser.0.*]');
                                        var cacheSelector = $('[id=parser.0.*]');
                                        schedule( "*/03 * * * * *",  function () {   
                                        var sortArr=[];
                                        var htmlString ="<table><tr><td>Bahn   </td><td>Wartezeit   </td><td>   </td></tr>";
                                        //console.log(cacheSelector);
                                        var counter =0;
                                        cacheSelector.each(function(id, i) {
                                        counter = counter+1
                                        var devicename = getObject(id).common.name;
                                        var ip = id.replace(/_/g, ".");
                                        var ip = ip.replace(/parser.0./g, "");
                                        // log(id + " : " + devicename + " : " + ip );
                                        var devicenameName=devicename;
                                        devicename="Park.Wartezeit"+counter.toString()+".BahnName";
                                        createState(devicename, 'empty', { name: 'Name der Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                        setStateDelayed(devicename, devicenameName, 800);
                                        devicename="Park.Wartezeit"+counter.toString()+".Bahn";
                                        setStateDelayed(devicename, ip, 800);
                                        createState('empty', { name: 'Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                        var wert2 = getState(id).val;
                                        var wert1 = getState(id).val;
                                        if (wert2) wert2 = "✅";
                                        if (!wert2) wert2= "❌";
                                        let help = [ip,wert1,wert2];
                                        sortArr.push(help);
                                        //log(sortArr[0]);
                                        });
                                        function numSort(a, b) { 
                                         return parseInt(b[1]) - parseInt(a[1]);
                                        } 
                                        sortArr.sort(numSort);
                                              for (var i=0; i<sortArr.length;i++) {
                                                  htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "   </td><td>" + sortArr[i][1] + "   </td><td>" + sortArr[i][2] +  "</td></tr>";
                                              }      
                                        //htmlString=htmlString.concat("<tr><td>" + devicenameName + "   </td><td>" + ip + "   </td><td>" + wert1 + "</td></tr>");
                                        //log(counter);
                                        createState('Park.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
                                        createState('Park.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
                                        setStateDelayed('Park.Anzahl', counter, 800);
                                        setStateDelayed('Park.StringHTML', htmlString.concat("</table>"), 800);
                                        });
                                        

                                        liv-in-sky 1 Reply Last reply Reply Quote 1
                                        • liv-in-sky
                                          liv-in-sky @Alexxx2005 last edited by liv-in-sky

                                          @Alexxx2005

                                          ok neuer test

                                          
                                          
                                          schedule( "*/20 * * * * *", function () {
                                          var cacheSelector = $('[id=parser.0.*]');
                                          var sortArr=[];
                                          var htmlString ="<table><tr><td>Bahn </td><td>Wartezeit </td><td> </td><td>&ensp;&ensp;&ensp;</td><td>Bahn &ensp;&ensp;&ensp;</td><td>Wartezeit </td><td> </td></tr>";/*+
                                                                 "<tr>&ensp;<td></td><td></td><td></td><td></td><td></td><td></td></tr>" */;
                                          //console.log(cacheSelector);
                                          var counter =0;
                                          
                                          cacheSelector.each(function(id, i) {
                                          
                                          counter = counter+1
                                          
                                          var devicename = getObject(id).common.name;
                                          
                                          var ip = id.replace(/_/g, ".");
                                          
                                          var ip = ip.replace(/parser.0./g, "");
                                          
                                          
                                          var ip = id.replace(/_/g, ".");
                                          var ip = ip.replace(/parser.0./g, "");
                                          // log(id + " : " + devicename + " : " + ip );
                                          var devicenameName=devicename;
                                          
                                          devicename="Park.Wartezeit"+counter.toString()+".BahnName";
                                          createState(devicename, 'empty', { name: 'Name der Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                          setStateDelayed(devicename, devicenameName, 800);
                                          devicename="Park.Wartezeit"+counter.toString()+".Bahn";
                                          setStateDelayed(devicename, ip, 800);
                                          createState(devicename,'empty', { name: 'Bahn', desc: '', type: 'string', role: '',read: true, write: true });
                                          var wert1;
                                          var wert2;
                                          if ( getState(id).val==null) {wert1= "🔒"; wert2="999999";} 
                                          else {
                                               
                                               var wert2 = getState(id).val;
                                               var wert1 = getState(id).val;
                                               if (wert1) wert1 = "✅";
                                               if (!wert1) wert1= "❌";
                                          }
                                          let help = [ip,wert2,wert1];
                                          sortArr.push(help);
                                          
                                          });
                                          function numSort(a, b) {
                                          return parseInt(a[1]) - parseInt(b[1]);
                                          }
                                          sortArr.sort(numSort);
                                          for (var i=0; i<sortArr.length;i++) {   
                                             if (sortArr[i][1]!="999999") {
                                             if(i%2==0) {htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "</td><td>&ensp;&ensp;&ensp;" + sortArr[i][1] + "&ensp;&ensp;&ensp;</td><td>" + sortArr[i][2]+"&ensp;&ensp;&ensp;"+"<td>&ensp;&ensp;&ensp;</td>" ;}// +"</td>"         + " <td>"        + " </td><td>"   + "</td></tr>";}
                                             else{htmlString=htmlString+      "<td>" + sortArr[i][0]  + " </td><td>&ensp;&ensp;&ensp;"   + sortArr[i][1]  + "&ensp;&ensp;&ensp;</td><td>"   + sortArr[i][2] + "</td></tr>"}}
                                             else{
                                                 if(i%2==0) {htmlString=htmlString+"<tr><td>" + sortArr[i][0] + "</td><td>&ensp;&ensp;&ensp;" + "out" + "&ensp;&ensp;&ensp;</td><td>" + sortArr[i][2]+"&ensp;&ensp;&ensp;" ;}// +"</td>"         + " <td>"        + " </td><td>"   + "</td></tr>";}
                                             else{htmlString=htmlString+      "<td>" + sortArr[i][0]  + " </td><td>&ensp;&ensp;&ensp;"   + "out"  + "&ensp;&ensp;&ensp;</td><td>"   + sortArr[i][2] + "</td></tr>"}
                                          
                                             }
                                          
                                          }
                                          //htmlString=htmlString.concat("<tr><td>" + devicenameName + " </td><td>" + ip + " </td><td>" + wert1 + "</td></tr>");
                                          //log(counter);
                                          createState('Park.StringHTML', 0, {name: 'StringHTML', desc: '', type: 'string', role: '',read: true, write: true });
                                          createState('Park.Anzahl', 0, { name: 'Anzahl', desc: 'Anzahl der Geräte', type: 'number', unit: '', min: '0', max: '255', role: '',read: true, write: true });
                                          setStateDelayed('Park.Anzahl', counter, 800);
                                          setStateDelayed('Park.StringHTML', htmlString.concat("</table>"), 800);
                                          });
                                          

                                          ich habe mal versucht, das ganze in 2 tabellen nebeneinander darzustellen - weiß nicht ob das gefällt ?

                                          test3.gif

                                          A 1 Reply Last reply Reply Quote 0
                                          • A
                                            Alexxx2005 @liv-in-sky last edited by

                                            @liv-in-sky

                                            doch das ist super , sieht gut aus. Es zeigt bei mir nur die oberen drei rechten Spalten zu weit links an , es da noch ein kleiner Bug im "htmlstring" oder warum zeigt es die drei markierten Bahnen so an ?

                                            Bug.PNG

                                            Grüße Alex

                                            Homoran liv-in-sky 3 Replies Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            483
                                            Online

                                            31.9k
                                            Users

                                            80.2k
                                            Topics

                                            1.3m
                                            Posts

                                            parser adapter
                                            5
                                            53
                                            2149
                                            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