NEWS
Daten aus PW geschützte Website
-
@latzi sagte in Daten aus PW geschützte Website:
leider sind bei mir die Längen der Array´s nicht gleich, dates & prices sind 3 mal länger
da gilt ein Eintrag für 3 Zeiträume, man sollte das eigentlich auch auf der Website sehen. Seltsam dass das bei @Negalein anders ist. Wie auch immer, du kannst das expandieren, indem du deine Zeile 69 durch folgende Zeilen ersetzt
const titles = []; const titlesTmp = $('div[class="panel-body"] > fieldset > legend > strong').map((i,el)=>$(el).text().replace("Preise","").trim()); for (let i = 0; i < 36; i++) { titles[i] = titlesTmp[Math.floor(i / 3)] };
-
@fastfoot sagte in Daten aus PW geschützte Website:
Seltsam dass das bei @Negalein anders ist.
Ja komisch. Ich seh im Portal nur den Preis für die aktuelle Woche.
@Latzi sieht in auch noch für die 2 Vorwochen.Sind zwar verschiedene Partner (Voest vs. Siedlerverein), aber gültig ist bei beiden nur der Preis von der aktuellen Woche.
-
@latzi sagte in Daten aus PW geschützte Website:
leider sind bei mir die Längen der Array´s nicht gleich, dates & prices sind 3 mal länger
ok, dann ist die seitenstruktur bei dir anders.
dann benötige ich die html seite.
bitte den folgenden code nach der zeile mitconst $ = cheerio.load(body);
einfügen.
das speichert den seiteninhalt in eine txt-datei
wenn du linux einsetzt musst du nix mehr machen.
bei windows musst du den pfad anpassen wo du auch schreiben darfst. da kann ich nix vorgeben.die text-datei dann bitte hier im forum hochladen.
falls das forum meckert wegen zu groß, dann bei einem beliebigen cloud-provider (dropbox, google drive, mega, etc) hochladen und die datei freigeben .try { fs.writeFileSync('/opt/iobroker/iobroker-data/iqcard.txt', body); // file written successfully } catch (err) { console.error(err); }
-
@fastfoot sagte in Daten aus PW geschützte Website:
ist hier auch so, console.info etc. funktionieren in iobroker nicht. Einfach durch log(text) ersetzen
und bei mir funktioniert console.debug, aber console.info nicht.
warum ist das inkonsistent?
auch in der doku steht nix.
ja log ist beschrieben, aber dennoch seltsam -
@oliverio das liegt daran dass
console
in der JS-Adapter Sandbox neu definiert wurde(werden musste!??) und deshalb nicht mit Node zu 100% übereinstimmt. Allerdings war ich mit meiner Einschätzungconsole.info etc. funktionieren in iobroker nicht.
etwas voreilig. Es funktionieren ,console.log, .error, .warn und .debug
-
@oliverio
vielen Dank, hier die Datei: iqcard.txt -
@oliverio
ich hab´s mal quick & dirty gelöst und die 3 Array´s umkopiert, da mich nur die österreichischen Preise interessieren, alsotitles
von i =0 .. 4 durchlaufen und vonprices
sowiedates
3*i dazu gestellt (auch die Preise der Vorwochen sind für mich nicht interessant).
Sieht dann so aus:for (var i=0;i<5;i++) { titles_n[i]=titles[i]; dates_n[i]=dates[3*i]; prices_n[i]=prices[3*i]; };
Vielen herzlichen Dank nochmals für deine Mühe!
-
@latzi Kannst du mir bitte dein vollständiges Script schicken, ich bekomm das mit den 3 Arrays irgendwie nicht hin.
-
@johgre
bitte sehr...Ich hab auch die JSON-Ausgabe verändert, damit das Inventwo-JSON-widget damit klarkommt.
Hast du auch die 3-Wochen-Ansicht?
-
@latzi Super Danke, jetzt bekomm ich auch die Daten rein. Nein, hab eigentlich auch nur eine Woche zur Ansicht, aber noch viele Europäische Länder mit unterschiedlichen Preisen.
-
@johgre sagte in Daten aus PW geschützte Website:
aber noch viele Europäische Länder mit unterschiedlichen Preisen
interessant wie unterschiedlich mit IQ verhandelt wird.
Wir (Siedlerverein) können nur in Österreich billiger tanken. -
-
@oliverio
klappt perfekt
Ergebnis-JSON mit 270 Zeilen ist eine Ansage -
@oliverio sagte in Daten aus PW geschützte Website:
So ein neuer Versuch, der jetzt beide Strukturen einheitlich behandelt.
Merci! Werde ich gleich tauschen!
-
Guten Morgen!
Habe gerade bemerkt, dass das Script nicht mehr funktioniert .
Bekomme folgende Meldung.09:04:25.313 info javascript.0 (1025547) Stop script script.js.common.IQ-Sprit 09:04:25.313 info javascript.1 (1025554) Stop script script.js.common.IQ-Sprit 09:04:26.352 info javascript.0 (1025547) Start javascript script.js.common.IQ-Sprit 09:04:26.364 error javascript.0 (1025547) script.js.common.IQ-Sprit: Error: Cannot find module 'cheerio' 09:04:26.366 error javascript.0 (1025547) at script.js.common.IQ-Sprit:9:17 09:04:26.366 error javascript.0 (1025547) at script.js.common.IQ-Sprit:136:3 09:04:26.387 info javascript.0 (1025547) script.js.common.IQ-Sprit: registered 0 subscriptions, 1 schedule, 0 messages, 0 logs and 0 file subscriptions
cheerio
hab ich aber in den Modulen hinzugefügt.Kannst du mal drüberschaun?
Danke
-
Cannot find module cheerio.
Schau mal in den Einstellungen des JavaScript Adapters,
Entferne den Eintrag cheerio und füge ihn erneut hinzu (evtl auch in 2 Schritten mit speichern nach dem entfernen.) -
@oliverio sagte in Daten aus PW geschützte Website:
Entferne den Eintrag cheerio und füge ihn erneut hinzu (evtl auch in 2 Schritten mit speichern nach dem entfernen.)
Danke
musste es 2x machen. Jetzt funktionierts wieder. -
ok, warum auch immer diese bibliothek rausgeflogen ist.
muss man mal beobachten, was beim nächsten update des javascript adapter passiert, evtl ist da noch ein Fehler, der nach einem update die zusätzlichen bibliotheken nicht überprüft und installiert (warum auch immer sie deinstalliert wurden) -
Der Thread ist zwar schon etwas älter und wenn ich ihn früher gefunden hätte, dann hätte ich mir vielleicht etwas Arbeit erspart, aber so bin ich auf eine weitere Lösung gekommen den Preis bei der IQ-Tankkarte nach Login automatisch abzufragen.
Ich mache das mit einem Bash-Script welches ich per Cron regelmäßig aufrufe.
Edit: Das Script habe ich so angepasst, dass Datum und alle Spritpreise in einzelne Datenpunkte von ioBroker geschrieben werden. Damit kann man auch die Werte auch unabhängig voneinander aufzeichnen und als Diagramme darstellen. In VIS sieht die aktuelle Preisanzeige dann bei mir so aus:
Erst wird ein Login durchgeführt und das Cookie gespeichert. Danach die aktuelle Preisseite heruntergeladen. Dann werden das Datum und die Preise extrahiert und in Datenpunkte bei ioBroker geschrieben. Anschließend wir die geladene Datei gelöscht.
Davor die Datenpunkte in ioBroker anlegen und die Zugangsdaten im Script eintragen.
#!/bin/bash # Einloggen und Cookie speichern wget --save-cookies cookies.txt \ --keep-session-cookies \ --post-data 'BENUID={username}&PASSWT={password}' \ --delete-after \ https://netservice.iqcard.at/de/login # Seite mit den Preisen speichern wget --load-cookies cookies.txt \ https://netservice.iqcard.at/de/netservice_preisinfo # gespeicherte Seite in Variable einlesen IQWeb=$(<netservice_preisinfo) # Daten auslesen Datum=$(echo "$IQWeb" | grep -A 1 "preismast hidden-xs" | tr "<>" " " | awk '{print $4}' | xargs) Diesel=$(echo "$IQWeb" | grep "preismastDieselPreis" | tr "<>" " " | awk '{print $3}' | tr "," "." | xargs) Benzin=$(echo "$IQWeb" | grep "preismastBenzinPreis" | tr "<>" " " | awk '{print $3}' | tr "," "." | xargs) Super=$(echo "$IQWeb" | grep "preismastSuperPreis" | tr "<>" " " | awk '{print $3}' | tr "," "." | xargs) SuperPlus=$(echo "$IQWeb" | grep "preismastSuperplusPreis" | tr "<>" " " | awk '{print $3}' | tr "," "." | xargs) # in ioBroker Datenpunkte schreiben if [[ -n "${Datum}" && -n "${Diesel}" && -n "${Benzin}" && -n "${Super}" && -n "${SuperPlus}" ]]; then Erg=$(curl -s http://{ip.from.io.broker}:8082/set/0_userdata.0.IQ_Card_Tankkarte.Datum?value=$Datum) Erg=$(curl -s http://{ip.from.io.broker}:8082/set/0_userdata.0.IQ_Card_Tankkarte.Diesel?value=$Diesel) Erg=$(curl -s http://{ip.from.io.broker}:8082/set/0_userdata.0.IQ_Card_Tankkarte.Benzin?value=$Benzin) Erg=$(curl -s http://{ip.from.io.broker}:8082/set/0_userdata.0.IQ_Card_Tankkarte.Super?value=$Super) Erg=$(curl -s http://{ip.from.io.broker}:8082/set/0_userdata.0.IQ_Card_Tankkarte.SuperPlus?value=$SuperPlus) fi # gespeicherte Seite löschen rm netservice_preisinfo
-
@oliverio sagte in Daten aus PW geschützte Website:
ok, warum auch immer diese bibliothek rausgeflogen ist.
Hallo Oliver!
Durch meinen Thread ist @liv-in-sky gerade dabei, das Script von
request
aufaxios
für mich umzustellen.
Allerdings klappt nicht alles.Könntest du da behilflich sein, oder hier helfen?