Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Ölpreis

    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

    SOLVED Ölpreis

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

      Hi.
      @the78mole funktioniert dein Script nicht mehr? Habe es bei mir getestet, die Datenpunkte werden angelegt, aber Werte nur 0.
      Und gibt es eine Möglichkeit dabei seinen eigenen Preis bezogen auf die PLZ zu bekommen?
      Das ist ja individuell.

      Die anderen 5 Scripte von @Oli funktionieren bei mir zwar, aber irgendwie immer nur wenn ich die Scripte starte. Am nächsten Tag werden keine Werte mehr angezeigt. Oder mache ich was falsch?

      Grüße
      atifan

      O 1 Reply Last reply Reply Quote 0
      • P
        pix last edited by pix

        Hallo Thisoft,

        habe deinen letzten Post leider nicht mehr gesehen und jetzt mal http://www.heizoel24.de/heizoelpreise verwendet. Und dort nur die Prognose für den nächsten Tag und nicht den aktuellen Preis. Denke, bei der großen Summe Geld, die man ausgibt, muss man eh noch mal den Preis vergleichen. Aber der Trend ist sicher mal aufschlussreich:

        Das Skript basiert auf meinem alten solar-wetter Skript. Ist eigentlich nicht groß was anderes.

        Es werden diese Prognosen für den nächsten Werktag gespeichert:

        __Preis,

        Trend in Prozent,

        Trend in Text__

        Datum der Vorhersage als Text aus der Webseite (nicht als Date-Objekt)

        Einen negativen Trend habe ich noch nicht testen können (gab heute keinen). Da muss ich vielleicht noch nachbessern.

        Skript startet jede Stunde zur Minute 59 und bei Skriptstart.

        /* Ölpreis abfragen
        Auf diese Anfrage hin: http://forum.iobroker.net/viewtopic.php?f=8&t=3455
        Quelle: heizoel24.de
        Basis: solar-wetter Skript
        erstellt: 03.08.2016 von pix
        */
        var logging = false;
        var link = 'http://www.heizoel24.de/heizoelpreise';
        // ab hier nix mehr ändern, solange die Webseite die Daten nicht ändert
        var idProgPrice =   'Heizoel.Forecast.Price',
           idProgText =    'Heizoel.Forecast.Text',
           idProgPercent = 'Heizoel.Forecast.Percent',
           idProgDate =    'Heizoel.Forecast.Date';
        
        createState(idProgPrice, {
           name: 'HeizOel24.de Vorhersage Preis',
           desc: 'Heizölpreis Prognose für den nächsten Werktag',
           type: 'number',
           def: 0,
           min: 0,
           unit: '€/100l'
        });
        createState(idProgText, {
           name: 'HeizOel24.de Vorhersage Text',
           desc: 'Heizölpreis Prognose für den nächsten Werktag',
           type: 'string',
           def: ''
        });
        createState(idProgPercent, {
           name: 'HeizOel24.de Vorhersage Änderung in Prozent',
           desc: 'Heizölpreis Prognose für den nächsten Werktag',
           type: 'number',
           def: 0,
           min: 0,
           max: 100,
           unit: '%'
        });
        createState(idProgDate, {
           name: 'HeizOel24.de Vorhersage Datum',
           desc: 'Heizölpreis Prognose für den nächsten Werktag, dieses Datum',
           type: 'string',
           def: ''
        });
        var request = require('request');
        function extractPrice(body,text1,text2) {
           var start = body.indexOf(text1) + text1.length;
           var ende = body.indexOf(text2,start);
           if (logging) log('Startposition: ' + start);
           if (logging) log('Endposition: ' + ende);
           var zwischenspeicher;
           if (((start != -1) && (ende != -1)) && (start
        

        Bitte um Feedback 🙂

        Gruß

        Pix

        EDIT 12.11.2016:

        Nach Umstellung der Quellwebseite wurde das Skript geändert http://forum.iobroker.net/viewtopic.php … 949#p39949

        Neue Version (Achtung defekt, wegen Forumumstellung):

        /* Ölpreis abfragen
        Auf diese Anfrage hin: http://forum.iobroker.net/viewtopic.php?f=8&t=3455
        am 4.11.2016 getestet, nach Änderung der Webseite nun Fehler
        Quelle: heizoel24.de
        Basis: solar-wetter Skript
        erstellt: 03.08.2016 von pix
        12.11.2016 Webseite liefert nicht mehr Prognose, sondern Ist-Preis. Skript angepasst
        */
        var logging = false;
        var link = 'http://www.heizoel24.de/heizoelpreise';
        // ab hier nix mehr ändern, solange die Webseite die Daten nicht ändert
        var request = require('request');
        var idPrice =   'Heizoel.Ist.Price',
           idPercent = 'Heizoel.Ist.Percent',
           idDate =    'Heizoel.Ist.Date';
        
        createState(idPrice, {
           name: 'HeizOel24.de Preis',
           desc: 'Heizölpreis für heute',
           type: 'number',
           def: 0,
           min: 0,
           unit: '€/100l'
        });
        createState(idPercent, {
           name: 'HeizOel24.de Änderung in Prozent zum Vortag',
           desc: 'Heizölpreisänderung zum Vortag',
           type: 'number',
           def: 0,
           min: 0,
           max: 100,
           unit: '%'
        });
        createState(idDate, {
           name: 'HeizOel24.de Datum',
           desc: 'Heizölpreis Zeitstempel (als String)',
           type: 'string',
           def: ''
        });
        function extractText(body,text1,text2) {
           var start = body.indexOf(text1) + text1.length;
           var ende = body.indexOf(text2,start);
           if (logging) log('Startposition: ' + start);
           if (logging) log('Endposition: ' + ende);
           var zwischenspeicher;
           if (((start != -1) && (ende != -1)) && (start <ende)) {/fehler/abfangen/zwischenspeicher="body.slice(start,ende);" if/(logging)/log(zwischenspeicher);/return(zwischenspeicher);/}/else/;/log(zwischenspeicher,/'error');/return(0);/ok/function/findprice/(body)/var/text1="class=&quot;middle&quot;>" ,/erstes/auftauchen/text2="<span class=&quot;currency&quot;>€</span>" price="extractText(body,text1,text2);" 50,54/price_array="price.split(',');" +/'.'/price_array[1];/log('heizöl/preis:/'/eur');/setstate(idprice,/parsefloat(price,10));/wert/in/objekt/schreiben/findpercent/percent="extractText(body,text1,text2);" percent_array="percent.split(',');" percent_array[1];/prozent:/percent.tofixed(2)/'%');/setstate(idpercent,/percent);/finddate/day="extractText(body,text1,text2);" &empty;/100l,/12.11.2016</span="">if (logging) log('Heizöl Datum: ' + day);
           var pdatum = findeDatum(day);
           setState(idDate, pdatum); // Wert in Objekt schreiben
        }
        function findeDatum (body) {   
           if (logging) log(body);
           var stringdatum_array = body.split('.'); // ∅ 100l, 12.11.2016
           var stringjahr = stringdatum_array[2].trim(); // 2016
           var stringmonat = stringdatum_array[1].trim(); // 11
           var stringtag_string = stringdatum_array[0].trim(); // ∅ 100l, 12
           var stringtag_array = stringtag_string.split(','); // bei Komma trennen
           var stringtag = stringtag_array[1].trim(); // 12
           var stringdatum = stringtag + '.' + stringmonat + '.' + parseInt(stringjahr,10);
           if (logging) log('Datum: ' + stringdatum);
           return(stringdatum);
        }
        function leseWebseite () {
           try {
               request(link, function (error, response, body) {
                   if (!error && response.statusCode == 200) {              // kein Fehler, Inhalt in body
                       findPrice(body);
                       findPercent(body);
                       findDate(body);
                       log('Heizöl-Preis von heizoel24.de eingelesen');
                   } else log(error,'error');                               // Error beim Einlesen
               });
           } catch (e) {
               log('Fehler (try) leseWebseite: ' + e, 'error');
           }   
        }
        // bei Skriptstart
        leseWebseite();
        // Schedule
        schedule("59 * * * *", leseWebseite);</ende))>
        

        EDIT 08.07.2019 Skript repariert (aus Archiv hergestellt):

        /* Ölpreis abfragen
        Auf diese Anfrage hin: http://forum.iobroker.net/viewtopic.php?f=8&t=3455
        am 4.11.2016 getestet, nach Änderung der Webseite nun Fehler
        Quelle: heizoel24.de
        Basis: solar-wetter Skript
        
        erstellt: 03.08.2016 von pix
        12.11.2016 Webseite liefert nicht mehr Prognose, sondern Ist-Preis. Skript angepasst
        29.08.2017 SKRIPT AUSGESCHALTET, DA NICHT IN GEBRAUCH
        */
        
        var logging = false;
        var link = 'http://www.heizoel24.de/heizoelpreise';
        
        // ab hier nix mehr ändern, solange die Webseite die Daten nicht ändert
        var request = require('request');
        var idPrice =   'Heizoel.Ist.Price',
           idPercent = 'Heizoel.Ist.Percent',
           idDate =    'Heizoel.Ist.Date';
           
        createState(idPrice, {
           name: 'HeizOel24.de Preis',
           desc: 'Heizölpreis für heute',
           type: 'number',
           def: 0,
           min: 0,
           unit: '€/100l'
        });
        createState(idPercent, {
           name: 'HeizOel24.de Änderung in Prozent zum Vortag',
           desc: 'Heizölpreisänderung zum Vortag',
           type: 'number',
           def: 0,
           min: 0,
           max: 100,
           unit: '%'
        });
        createState(idDate, {
           name: 'HeizOel24.de Datum',
           desc: 'Heizölpreis Zeitstempel (als String)',
           type: 'string',
           def: ''
        });
        
        function extractText(body,text1,text2) {
           var start = body.indexOf(text1) + text1.length;
           var ende = body.indexOf(text2,start);
           if (logging) log('Startposition: ' + start);
           if (logging) log('Endposition: ' + ende);
           var zwischenspeicher;
           if (((start != -1) && (ende != -1)) && (start<ende)) {                      // Fehler abfangen
               zwischenspeicher = body.slice(start,ende);
               zwischenspeicher = zwischenspeicher.trim();
               if (logging) log(zwischenspeicher);
               return(zwischenspeicher);
           } else {
               zwischenspeicher = 'Fehler beim Ausschneiden';
               log(zwischenspeicher, 'error');
               return(0);
           }
        }
        
        //ok
        function findPrice (body) {   
           var text1 = 'class="middle">', // erstes Auftauchen
               text2 = '<span class="currency">€</span>';  // erstes Auftauchen
           var price = extractText(body,text1,text2); // 50,54 
           var price_array = price.split(',');
           price = price_array[0] + '.' + price_array[1];
           price = parseFloat(price);
           if (logging) log('Heizöl Preis: ' + price + ' EUR');
           setState(idPrice, parseFloat(price,10));                                 // Wert in Objekt schreiben
        }
        
        function findPercent (body) {   
           var text1 = '<span class="lower"><span class=" red">', // erstes Auftauchen
               text2 = '%</span> zum Vortag</span>';  // erstes Auftauchen
           var percent = extractText(body,text1,text2); // 50,54 
           var percent_array = percent.split(',');
           percent = percent_array[0] + '.' + percent_array[1];
           percent = parseFloat(percent);
           if (logging) log('Heizöl Prozent: ' + percent.toFixed(2) + '%');
           setState(idPercent, percent);                                 // Wert in Objekt schreiben
        }
        
        function findDate (body) {   
           var text1 = 'class="upper">', // erstes Auftauchen + 1 Tag
               text2 = 'class="middle">';                        // erstes Auftauchen
           var day = extractText(body,text1,text2); // &empty; 100l, 12.11.2016</span>
           if (logging) log('Heizöl Datum: ' + day);
           var pdatum = findeDatum(day);
           setState(idDate, pdatum);                                 // Wert in Objekt schreiben
        }
        
        function findeDatum (body) {   
           if (logging) log(body);
           var stringdatum_array = body.split('.'); // &empty; 100l, 12.11.2016
           var stringjahr = stringdatum_array[2].trim(); // 2016
           var stringmonat = stringdatum_array[1].trim(); // 11
           var stringtag_string = stringdatum_array[0].trim(); // &empty; 100l, 12
           var stringtag_array = stringtag_string.split(','); // bei Komma trennen
           var stringtag = stringtag_array[1].trim(); // 12
           var stringdatum = stringtag + '.' + stringmonat + '.' + parseInt(stringjahr,10);
           if (logging) log('Datum: ' + stringdatum);
           return(stringdatum);
        }
        
        function leseWebseite () {
           try {
               request(link, function (error, response, body) {
                   if (!error && response.statusCode == 200) {              // kein Fehler, Inhalt in body
                       findPrice(body);
                       findPercent(body);
                       findDate(body);
                       log('Heizöl-Preis von heizoel24.de eingelesen');
                   } else log(error,'error');                               // Error beim Einlesen
               });
           } catch (e) {
               log('Fehler (try) leseWebseite: ' + e, 'error');
           }   
        }
        
        // bei Skriptstart
        leseWebseite();
        
        // Schedule
        schedule("59 * * * *", leseWebseite);
        
        

        Gruß
        Pix

        1 Reply Last reply Reply Quote 0
        • O
          Oli @Atifan last edited by

          @Atifan
          hast du auch die aktuellsten?

          1 Reply Last reply Reply Quote 0
          • Atifan
            Atifan last edited by Atifan

            @Oli ich denke schon, aber kannst du mir evtl. posten wo genau das aktuellste ist? Nicht dass ich doch ein älteres erwischt habe. Funktioniert es bei dir wie gewollt?
            Ich habe die Anzeige auch nicht über VIS eingebunden, kann es was damit zu tun haben?

            Ich habe die 5 Scripte einfach gestart. Dann werden ja die Datenpunkte erzeugt.
            Dann logge ich einfach den Datenpunkt mit dem aktuellen Ölpreis für meine PLZ bei 3000L Abnahme in einer influxdb.
            Diesen Datenpunkt aus der influxdb visualisiere ich dann über grafana.
            Funktioniert das so mit deinem Script?
            Da steht ja irgendwas von VIS Oberfläche Button drücken oder aktualisieren, nicht dass es damit was zu tun hat dass es bei mir nicht funktioniert?

            Habe die 5 Scripte aus dem Thread hier aus Beitrag Nr.1, daher denke ich sind alle aktuell.
            https://forum.iobroker.net/topic/23885/vorlage-heizölpreisabfrage-über-esyoil-com

            O 1 Reply Last reply Reply Quote 0
            • O
              Oli @Atifan last edited by

              @Atifan

              das sind dann die aktuellen Scripte.

              ich kann leider weder was zu influxdb, noch zu grafana sagen,weil ich beides nicht nutze.

              Es hat mit dem Button für die Vis zu tun, das Script zur Preisabfrage für den Wohnort wird nur nach den Klick auf den Button ausgeführt.

              1 Reply Last reply Reply Quote 0
              • Atifan
                Atifan last edited by

                Alles klar. Dann wird es daran liegen, dass meine Daten immer nur nach dem Script Neustart aktualisiert werden und nicht zwischendurch.
                Aber das kann man doch dann ändern, dass es nicht durch den VIS Button gestartet wird sondern durch einen Cron.
                Irgendjemand der sich mit Javascript auskennt könnte das doch bestimmt anpassen? 😄

                1 Reply Last reply Reply Quote 0
                • Atifan
                  Atifan last edited by

                  Bzw.wenn ich das richtig verstehe, brauche ich doch eigentlich nur
                  Script1 zum Anlegen der States
                  Script3 zum automatisch Aktualisieren des Ölpreises an meiner PLZ
                  Script5 zum automatischen Aktualisieren des allgemeinen Ölpreises

                  Und das müsste doch auch ohne Änderungen am Script eigentlich funktionieren, oder nicht?

                  O 1 Reply Last reply Reply Quote 0
                  • O
                    Oli @Atifan last edited by Oli

                    @Atifan

                    versuche mal das scheudle aus Script 3 außerhalb der Klammer zu setzen.

                    Ansonsten würde ich gerne alles was meine Scripte betrifft, in meinem Beitrag weiterschreiben.

                    Atifan 1 Reply Last reply Reply Quote 0
                    • Atifan
                      Atifan @Oli last edited by

                      Hi,
                      habe hier das Script die ganze Zeit genutzt, aber seit einiger Zeit funktioniert es nicht mehr. Weiss einer warum?
                      Danke!

                      /* Ölpreis abfragen
                      Auf diese Anfrage hin: http://forum.iobroker.net/viewtopic.php?f=8&t=3455
                      am 4.11.2016 getestet, nach Änderung der Webseite nun Fehler
                      Quelle: heizoel24.de
                      Basis: solar-wetter Skript
                      {1}
                      erstellt: 03.08.2016 von pix
                      12.11.2016 Webseite liefert nicht mehr Prognose, sondern Ist-Preis. Skript angepasst
                      29.08.2017 SKRIPT AUSGESCHALTET, DA NICHT IN GEBRAUCH
                      */
                       
                      var logging = false;
                      var link = 'http://www.heizoel24.de/heizoelpreise';
                       
                      // ab hier nix mehr ändern, solange die Webseite die Daten nicht ändert
                      var request = require('request');
                      var idPrice =   'Heizoel.Ist.Price',
                         idPercent = 'Heizoel.Ist.Percent',
                         idDate =    'Heizoel.Ist.Date';
                         
                      createState(idPrice, {
                         name: 'HeizOel24.de Preis',
                         desc: 'Heizölpreis für heute',
                         type: 'number',
                         def: 0,
                         min: 0,
                         unit: '€/100l'
                      });
                      createState(idPercent, {
                         name: 'HeizOel24.de Änderung in Prozent zum Vortag',
                         desc: 'Heizölpreisänderung zum Vortag',
                         type: 'number',
                         def: 0,
                         min: 0,
                         max: 100,
                         unit: '%'
                      });
                      createState(idDate, {
                         name: 'HeizOel24.de Datum',
                         desc: 'Heizölpreis Zeitstempel (als String)',
                         type: 'string',
                         def: ''
                      });
                       
                      function extractText(body,text1,text2) {
                         var start = body.indexOf(text1) + text1.length;
                         var ende = body.indexOf(text2,start);
                         if (logging) log('Startposition: ' + start);
                         if (logging) log('Endposition: ' + ende);
                         var zwischenspeicher;
                         if (((start != -1) && (ende != -1)) && (start<ende)) {                      // Fehler abfangen
                             zwischenspeicher = body.slice(start,ende);
                             zwischenspeicher = zwischenspeicher.trim();
                             if (logging) log(zwischenspeicher);
                             return(zwischenspeicher);
                         } else {
                             zwischenspeicher = 'Fehler beim Ausschneiden';
                             log(zwischenspeicher, 'error');
                             return(0);
                         }
                      }
                       
                      //ok
                      function findPrice (body) {   
                         var text1 = 'class="middle">', // erstes Auftauchen
                             text2 = '<span class="currency">€</span>';  // erstes Auftauchen
                         var price = extractText(body,text1,text2); // 50,54 
                         var price_array = price.split(',');
                         price = price_array[0] + '.' + price_array[1];
                         price = parseFloat(price);
                         if (logging) log('Heizöl Preis: ' + price + ' EUR');
                         setState(idPrice, parseFloat(price,10));                                 // Wert in Objekt schreiben
                      }
                       
                      function findPercent (body) {   
                         var text1 = '<span class="lower"><span class=" red">', // erstes Auftauchen
                             text2 = '%</span> zum Vortag</span>';  // erstes Auftauchen
                         var percent = extractText(body,text1,text2); // 50,54 
                         var percent_array = percent.split(',');
                         percent = percent_array[0] + '.' + percent_array[1];
                         percent = parseFloat(percent);
                         if (logging) log('Heizöl Prozent: ' + percent.toFixed(2) + '%');
                         setState(idPercent, percent);                                 // Wert in Objekt schreiben
                      }
                       
                      function findDate (body) {   
                         var text1 = 'class="upper">', // erstes Auftauchen + 1 Tag
                             text2 = 'class="middle">';                        // erstes Auftauchen
                         var day = extractText(body,text1,text2); // &empty; 100l, 12.11.2016</span>
                         if (logging) log('Heizöl Datum: ' + day);
                         var pdatum = findeDatum(day);
                         setState(idDate, pdatum);                                 // Wert in Objekt schreiben
                      }
                       
                      function findeDatum (body) {   
                         if (logging) log(body);
                         var stringdatum_array = body.split('.'); // &empty; 100l, 12.11.2016
                         var stringjahr = stringdatum_array[2].trim(); // 2016
                         var stringmonat = stringdatum_array[1].trim(); // 11
                         var stringtag_string = stringdatum_array[0].trim(); // &empty; 100l, 12
                         var stringtag_array = stringtag_string.split(','); // bei Komma trennen
                         var stringtag = stringtag_array[1].trim(); // 12
                         var stringdatum = stringtag + '.' + stringmonat + '.' + parseInt(stringjahr,10);
                         if (logging) log('Datum: ' + stringdatum);
                         return(stringdatum);
                      }
                       
                      function leseWebseite () {
                         try {
                             request(link, function (error, response, body) {
                                 if (!error && response.statusCode == 200) {              // kein Fehler, Inhalt in body
                                     findPrice(body);
                                     findPercent(body);
                                     findDate(body);
                                     log('Heizöl-Preis von heizoel24.de eingelesen');
                                 } else log(error,'error');                               // Error beim Einlesen
                             });
                         } catch (e) {
                             log('Fehler (try) leseWebseite: ' + e, 'error');
                         }   
                      }
                       
                      // bei Skriptstart
                      leseWebseite();
                       
                      // Schedule
                      schedule("59 * * * *", leseWebseite);
                       
                      
                      
                      A 1 Reply Last reply Reply Quote 0
                      • A
                        Adnim @Atifan last edited by

                        Hi!
                        bei mir das gleiche, es gibt auch eine Fehlermeldung im LOG dazu, kann jemand helfen?

                        javascript.0	2020-08-24 09:43:26.086	error	(680) Error in request callback: TypeError: body.split is not a function
                        javascript.0	2020-08-24 09:43:26.086	error	(680) script.js.common.oelpreis: Fehler beim Ausschneiden
                        

                        Danke!

                        Atifan 1 Reply Last reply Reply Quote 0
                        • Atifan
                          Atifan @Adnim last edited by Atifan

                          hier stand Müll

                          1 Reply 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

                          902
                          Online

                          31.9k
                          Users

                          80.1k
                          Topics

                          1.3m
                          Posts

                          javascript
                          15
                          65
                          12739
                          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