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.
    • 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
                                    • Homoran
                                      Homoran Global Moderator Administrators @Alexxx2005 last edited by

                                      @Alexxx2005 sagte in Adapter - Parser soll Wartezeiten auslesen:

                                      Es zeigt bei mir nur die oberen drei rechten Spalten zu weit links an

                                      ich tippe darauf, dass es an dem Schloss - icon, resp. der dazugehörigen Formatierung liegt

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

                                        @Alexxx2005 ich überprüfe nochmal - falls du was am script geändert hast, bitte wieder posten, damit ich damit arbeiten kann, sonst musst du wieder nachträglich ändern

                                        nur zur sicherheit - die werte stimmen alle ? es geht nur um die formatierung ?

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

                                          @Alexxx2005 du kannst mal zum test das schloss mit einem haken austauschen und nachsehen, ob das problem bleibt - somit könnten wir das icon ausschließem ( @Homoran )

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

                                            @Homoran

                                            beim Haken oder X ist es gleich

                                            bug2.PNG

                                            @liv-in-sky

                                            im Skript habe ich nur bei Zeile 54/55 das Wort "out" entfernt

                                            Zeile54.PNG

                                            und die Sortierung (b und a) in Zeile 46 sonst ist alles genau gleich wie das
                                            wo du gepostet hast 🙂

                                            Grüße Alex

                                            liv-in-sky 2 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

                                            465
                                            Online

                                            31.9k
                                            Users

                                            80.2k
                                            Topics

                                            1.3m
                                            Posts

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