Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. JSON Tabelle FuelPriceMonitor [Austria]

    NEWS

    • Amazon Alexa - ioBroker Skill läuft aus ?

    • Monatsrückblick – September 2025

    • Neues Video "KI im Smart Home" - ioBroker plus n8n

    JSON Tabelle FuelPriceMonitor [Austria]

    This topic has been deleted. Only users with topic management privileges can see it.
    • M
      mrfloppy @liv-in-sky last edited by

      @liv-in-sky
      das kann ich nicht ganz genau sagen aber so 6-7 km.
      Ich wei snur das gestern die Km drinnen gestanden sind aber halt ean einer anderen Position.
      Ich beobachte das weiter

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

        @mrfloppy ich denke. ich weiß den fehler - vermute ich eher

        hier siehst du die id doppelt in den datenpunkten - wenn der wert null ist, wird die heimadresse angegeben - ich weiß nicht, warum das 2mal vorkommt

        bitte prüfe das mal bei dir

        Image 203.png
        meine dp:
        Image 202.png

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

          @mrfloppy

          ändere mal diese zeile 151

          Image 204.png

          das ist der code zum einsetzen:

          else {if (ergebnis=="") ergebnis=mylat+','+mylong}
          
          M 2 Replies Last reply Reply Quote 0
          • M
            mrfloppy @liv-in-sky last edited by

            @liv-in-sky
            Jetzt hat Aderklaa einen Km Angabe.
            Werde das beobachten
            DAnke

            Screenshot 2023-02-13 165807.jpg

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

              @liv-in-sky
              schau mal

              Screenshot 2023-02-13 202548.jpg Screenshot 2023-02-13 165807.jpg

              vor 3Std hatte der Lohberger noch KM, jetzt nicht mehr.

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

                @mrfloppy

                dann müßtest du bitte mal rausfinden, ob es wieder diese ID öfters als ordner gibt

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

                  @liv-in-sky sehe gerade was anderes-> schau mal
                  dd8d397c-8133-45c2-9d84-ffcb3ee14c16-image.png
                  da stimmt was mit der liste gar nicht
                  der ist gar nicht auf Platz 2 (DP 1)

                  Edit: Wenn ich das Script neu starte stimmt die JsonListe in der VIS
                  Ist das Update deines Scriptes ev zu schnell? Und die DP noch nicht fertig geschrieben im FUELPRICE?

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

                    @mrfloppy hast du mal den browser refresht - evtl sind die dp nicht upgerdatet im admin

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

                      @liv-in-sky ja habe ich gehabt

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

                        @mrfloppy

                        ich muss das morgen ansehen - heute geht leider nicht

                        aber wenn ich so schnell drüber nachdenke - das script wird getriggert, wenn der erste dp geschrieben wird - evtl kann tatsächlich das script schneller sein, als der adapter

                        du kannst mal das noch testen ungefähr bei zeile 70 diesen "on" block austauschen mit

                        on({id: triggerArr, change: "ne"}, async function (obj) {
                            var value = obj.state.val;
                            var oldValue = obj.oldState.val;
                            if (myPause) {setTimeout(async function () { mainFunc();}, 5000); /*log("Wert: "+value+" ID: "+obj.id+" AlterWert: "+oldValue);*/ myPause=false; setTimeout(async function () { myPause=true;}, 10000);}
                          });
                        
                        M 1 Reply Last reply Reply Quote 0
                        • M
                          mrfloppy @liv-in-sky last edited by

                          @liv-in-sky
                          danke, getauscht und werde beobachten die nächsten Tage

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

                            @mrfloppy ich hatte heute morgen auch 2 mit 0 als km - da waren aber tasächlich 2 ordner mit der id vorhanden und in beiden ordnern war die location null

                            von daher

                            • wenn wieder ein 0km steht, bitte nach den ordnern mit der id suchen und kontrollieren, ob da was drinsteht
                            • und auch ab und zu die daten auf richtigkeit überprüfen - es muss nämlich ein ganz besonderer fall sein, damit da die alten daten drinstehen - und zwar, wenn einer der ersten 2-3 datensätze verändert wird, dann kann es sein, das das script sofort losgelaufen ist und schneller war als der adapter - sollte aber jetzt behoben sein
                            1 Reply Last reply Reply Quote 0
                            • Negalein
                              Negalein Global Moderator @liv-in-sky last edited by Negalein

                              @liv-in-sky

                              Servus

                              Bin erst jetzt (komplett übersehn) auf dein Script gestossen.

                              Du verwendest hier cheapest overall.

                              Ist es möglich, stattdessen fuelpricemonitor.0.0_Home_Diesel zu verwenden?

                              40fa0161-2154-4c9d-adbb-d57c4fd7315d-image.png

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

                                @negalein

                                habe im moment wenig zeit - muss mir das nochmal ansehen - evtl am WE

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

                                  @negalein

                                  habe nochmal darüber geschaut - das umzustellen ist zu aufwendig - die frage ist aber ob das sinnvoll ist

                                  du bekommst die tankstellen deiner umgebung (abhängig von deinen koordinaten) zusätzlich kannst du weitere tankst. eingeben. in overall ist dann eine liste nach preis.

                                  wenn du in der instanz alle zusätzlichen tankstellen rausnimmst, sollte eigentlich in 0_home-diesel das selbe stehen, wie in cheapestall-diesel - das was du eigentlich möchtest

                                  musst du testen

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

                                    @liv-in-sky
                                    kann man das für die VIS-2 auch verwenden?

                                    bei mir werden keine logos dargestellt, nur der Pfad, welcher richtig ist.
                                    44fe7273-92a6-42bd-a268-29acd86a59d0-grafik.png

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

                                      @australien hi, schau mal im widget selbst, ob es für die spalte mit dem pfad eine einstellung gibt für "bild"

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

                                        @liv-in-sky ich kann dazu leider im basic und inventwo nicht finden.
                                        welches verwendest du?

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

                                          @australien

                                          ich nutze das nicht - wohne nicht in AUT

                                          du kannst dafür nur das json inventwo widget nutzen - ich habe kein vis 2, daher kenne ich das widget darin nicht - ich kann mich aber erinnbern, daß in vis 1 man die spalte als bild definieren muss, sonst wird halt nur der pfad angezeigt

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

                                            @liv-in-sky ich habe mir nun in einen script eine html Ausgabe erstellen lassen, passt soweit.

                                            // Dieses Skript liest zwei JSON-Datenpunkte (für Diesel & Super) aus
                                            // und erstellt daraus zwei separate HTML-Tabellen für VIS-2.
                                            //
                                            // ✅ Quellen:
                                            //   - 0_userdata.0.FUELPRICEMONITOR.DIEJsonAnzeige  → enthält Feld "DIE" für Logo
                                            //   - 0_userdata.0.FUELPRICEMONITOR.SUPJsonAnzeige  → enthält Feld "SUP" für Logo
                                            //
                                            // ✅ Ziel-Datenpunkte (HTML für VIS-2):
                                            //   - 0_userdata.0.FUELPRICEMONITOR.DIETankstellen_HTML
                                            //   - 0_userdata.0.FUELPRICEMONITOR.SUPTankstellen_HTML
                                            //
                                            // Logos werden anhand des jeweiligen Feldes (SUP oder DIE) oder – falls leer – anhand des Firmennamens automatisch zugeordnet.
                                            
                                            // ------------------------- EINSTELLUNGEN -------------------------
                                            const srcDIE = '0_userdata.0.FUELPRICEMONITOR.DIEJsonAnzeige';
                                            const srcSUP = '0_userdata.0.FUELPRICEMONITOR.SUPJsonAnzeige';
                                            const dpDIE  = '0_userdata.0.FUELPRICEMONITOR.DIETankstellen_HTML';
                                            const dpSUP  = '0_userdata.0.FUELPRICEMONITOR.SUPTankstellen_HTML';
                                            // -----------------------------------------------------------------
                                            
                                            // Liste aller Tankstellen-Logos
                                            const logoList = [
                                              { firma: "BP", pic: "/vis-2.0/doki/Tankstellen/bp.png" },
                                              { firma: "Genol", pic: "/vis-2.0/doki/Tankstellen/genol.png" },
                                              { firma: "eni", pic: "/vis-2.0/doki/Tankstellen/eni.png" },
                                              { firma: "Turmöl", pic: "/vis-2.0/doki/Tankstellen/turmoel.png" },
                                              { firma: "paradies", pic: "/vis-2.0/doki/Tankstellen/treibstoffparadies.png" },
                                              { firma: "Lohberger", pic: "/vis-2.0/doki/Tankstellen/lohberger.png" },
                                              { firma: "SB-Tankstelle", pic: "/vis-2.0/doki/Tankstellen/sb.jpg" },
                                              { firma: "Diskont", pic: "/vis-2.0/doki/Tankstellen/hofer.png" },
                                              { firma: "AVIA", pic: "/vis-2.0/doki/Tankstellen/avia.png" },
                                              { firma: "AVANTI", pic: "/vis-2.0/doki/Tankstellen/avanti.png" },
                                              { firma: "Shell", pic: "/vis-2.0/doki/Tankstellen/shell.png" },
                                              { firma: "Aral", pic: "/vis-2.0/doki/Tankstellen/aral.png" },
                                              { firma: "JET", pic: "/vis-2.0/doki/Tankstellen/jet.png" },
                                              { firma: "Ultsch", pic: "/vis-2.0/doki/Tankstellen/ultsch.png" },
                                              { firma: "IQ", pic: "/vis-2.0/doki/Tankstellen/iq.jpg" },
                                              { firma: "SOCAR", pic: "/vis-2.0/doki/Tankstellen/socar.png" },
                                              { firma: "OIL!", pic: "/vis-2.0/doki/Tankstellen/oil.png" },
                                              { firma: "bft", pic: "/vis-2.0/doki/Tankstellen/bft.png" },
                                              { firma: "default", pic: "/vis-2.0/doki/Tankstellen/default.png" }
                                            ];
                                            
                                            // Funktion: passendes Logo anhand des Namens ermitteln
                                            function getLogoByName(name) {
                                              if (!name) return "/vis-2.0/doki/Tankstellen/default.png";
                                              const lower = name.toLowerCase();
                                              for (let entry of logoList) {
                                                if (lower.includes(entry.firma.toLowerCase())) {
                                                  return entry.pic;
                                                }
                                              }
                                              return "/vis-2.0/doki/Tankstellen/default.png";
                                            }
                                            
                                            // Funktion zur Erstellung der HTML-Tabelle
                                            function createTankstellenHTML(tankstellen, titel, type) {
                                              let html = `
                                              <style>
                                                table.tankstellen {
                                                  width: 100%;
                                                  border-collapse: collapse;
                                                  font-family: Arial, sans-serif;
                                                  font-size: 14px;
                                                }
                                                table.tankstellen th {
                                                  background-color: #ddd;
                                                  padding: 8px;
                                                  text-align: left;
                                                }
                                                table.tankstellen td {
                                                  padding: 8px;
                                                  border-bottom: 1px solid #ccc;
                                                }
                                                table.tankstellen img {
                                                  width: 50px;
                                                  height: auto;
                                                }
                                                h3.titel {
                                                  font-family: Arial, sans-serif;
                                                  margin-bottom: 8px;
                                                  margin-top: 10px;
                                                }
                                              </style>
                                            
                                              <h3 class="titel">${titel}</h3>
                                              <table class="tankstellen">
                                                <tr>
                                                  <th>Logo</th>
                                                  <th>Name</th>
                                                  <th>Adresse</th>
                                                  <th>Preis (€)</th>
                                                </tr>`;
                                            
                                              for (let t of tankstellen) {
                                                // Logo-Feld je nach Typ
                                                let logo = type === 'DIE' ? t.DIE : t.SUP;
                                            
                                                // Wenn leer → anhand des Namens bestimmen
                                                if (!logo || logo.trim() === '') {
                                                  logo = getLogoByName(t.Name);
                                                }
                                            
                                                html += `
                                                <tr>
                                                  <td style="text-align:center;"><img src="${logo}" alt="Logo"></td>
                                                  <td>${t.Name || '-'}</td>
                                                  <td>${t.Adresse || '-'}</td>
                                                  <td>${t.Preis ? t.Preis.toFixed(3) : '-'}</td>
                                                </tr>`;
                                              }
                                            
                                              html += `</table>`;
                                              return html;
                                            }
                                            
                                            // Ziel-Datenpunkte anlegen, falls nicht vorhanden
                                            if (!existsState(dpDIE)) {
                                              createState(dpDIE, { name: 'DIE Tankstellen HTML', type: 'string', role: 'html', read: true, write: true });
                                            }
                                            if (!existsState(dpSUP)) {
                                              createState(dpSUP, { name: 'SUP Tankstellen HTML', type: 'string', role: 'html', read: true, write: true });
                                            }
                                            
                                            // Hauptfunktion zum Aktualisieren der Tabellen
                                            async function updateTankstellen() {
                                              try {
                                                // Diesel
                                                const rawDIE = getState(srcDIE)?.val;
                                                if (rawDIE) {
                                                  const dieselData = JSON.parse(rawDIE);
                                                  const htmlDIE = createTankstellenHTML(dieselData, 'Diesel – Tankstellen', 'DIE');
                                                  setState(dpDIE, htmlDIE, true);
                                                  log(`✅ Diesel-Tabelle aktualisiert (${dieselData.length} Einträge).`);
                                                } else {
                                                  log(`⚠️ Keine Daten in ${srcDIE}`, 'warn');
                                                }
                                            
                                                // Super
                                                const rawSUP = getState(srcSUP)?.val;
                                                if (rawSUP) {
                                                  const superData = JSON.parse(rawSUP);
                                                  const htmlSUP = createTankstellenHTML(superData, 'Super – Tankstellen', 'SUP');
                                                  setState(dpSUP, htmlSUP, true);
                                                  log(`✅ Super-Tabelle aktualisiert (${superData.length} Einträge).`);
                                                } else {
                                                  log(`⚠️ Keine Daten in ${srcSUP}`, 'warn');
                                                }
                                            
                                              } catch (err) {
                                                log('❌ Fehler beim Erstellen der Tankstellen-Tabellen: ' + err, 'error');
                                              }
                                            }
                                            
                                            // Trigger bei Änderungen an den JSON-Datenpunkten
                                            on({ id: srcDIE, change: 'any' }, updateTankstellen);
                                            on({ id: srcSUP, change: 'any' }, updateTankstellen);
                                            
                                            // Beim Start sofort ausführen
                                            updateTankstellen();
                                            
                                            

                                            Gibt es noch eine Möglichkeit die fuelpricemonitor.0.0_Home_Diesel und nicht die fuelpricemonitor.0.cheapestOverAll_DIE für die Erstellung der jsonAusgabe zu verwenden? vv Super

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            716
                                            Online

                                            32.3k
                                            Users

                                            81.1k
                                            Topics

                                            1.3m
                                            Posts

                                            6
                                            77
                                            6418
                                            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