NEWS
Wunsch: Pollenflug-(Adapter/wasauchimmer)
-
@SBorg sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):
Wie heißt es immer so schön: ich habe eine gute und eine schlechte Nachricht...
Die "gute": ich weiß woran es liegt...
die "schlechte": ich bin dann mal raus...Schade aber trotzdem vielen Dank für die Mühe die Du dir gemacht hast
-
@Homoran sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):
@SBorg sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):
Solange man es anscheinend kpl. in Ruhe lässt funktioniert es...
Mir fällt gerade die Meldung auf:
TypeScript compilation successful
Das macht der Adapter bei jedem Start eines TypeScripts (also bei Änderung und bei Adapterstart).
-
@Homoran sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):
ob ich das mal machen sollte?
Hattest du das mal bei dir gemacht ? Habe das mal installiert allerdings zeigte das Debian nach einem Neustart wieder die alte 6.4.1 bei mir an ... weiss immer noch nicht wodran das liegt
-
@Segway sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):
Hattest du das mal bei dir gemacht ?
Ja!
und npm -v ergibt auch brav 6.9.0 -
-
@Segway nein als user pi mit
sudo -H npm install -g npm
-
-
Hallo
Hatte das Skript das ganze letzte Jahr am laufen
-
nun nach dem Winter habe ich es wieder gestartet!
nun gleich einen ERROR20:20:23.749 error javascript.0 script.js.common.Polleninfo compile failed:
at script.js.common.Polleninfo:9Das ich gerade gesehen habe das es auch bereits einen Adapter gibt habe ich ihn probiert.
Nur geht das nicht weil ich aus österreich bin und dafür keine Eonstellungen giebt.Was bedeutet der Error.
Danke -
Du kannst die letzten ~50 Posts bei Interesse dazu lesen, oder kurz und schmerzlos: der Aufbau der Seite hat sich geändert und der Parser funktioniert nicht mehr...
-
@SBorg
und wenn jemand Zeit, Lust und die Fähigkeit hat das Skript zu modifizieren (mir fehlt vor allem letzteres), habe ich schon mal etwas vorbereitetMit dem Regex
day0="(\w+)
erhält man für die 14 Pollenarten die heutige Warnstufe
Ändert man day0 auf day1 ist das die morgige Warnstufe, day2 übermorgen usw.Als Ergebnis kommen vier verschiedene Worte heraus: noburden, weakburden, moderateburden und strongborden, was den Intensitäten 0-3 entspricht, was dann noch umgerechnet werden muss.
Mit dem Parser geht es leider nicht, da kommt 503-forbidden.
(Oder kann man im Aufruf der Adresse einen Useragent mitgeben?)Die entsprechenden Pollenarten erhält man mit
xt">(\w+)
Wobei ich davon ausgehe, dass sich die Reihenfolge nicht ändert und man einfach 0=Erle, 1=Hasel usw. festlegen kännte
-
@Homoran sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):
(Oder kann man im Aufruf der Adresse einen Useragent mitgeben?)
Nicht das ich wüsste. Ich gebe ihn bei meinem Shell-Script auch per wget mit.
-
@Homoran sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):
Oder kann man im Aufruf der Adresse einen Useragent mitgeben
Natürlich:
https://github.com/request/request#custom-http-headers -
@Homoran meinte aber IMO beim Parser-Adapter...?
-
@SBorg
So ist es -
Ok da bin ich raus
-
@AlCalzone
und ich bei einem Skript -
Wie sehr willst du es denn?
Out-of-the-box kann ich dir höchstens mein Shell-Script anbieten:
Ist halt kein Adapter, benutzt Simpel-API und wird per crontab getriggert. Kann dafür aber jeden Ort, liefert was WetterOnline anbietet, allerdings meinen Bedürfnissen angepasst. -
Hallo zusammen,
ich war mal so frei und hab es soweit mir möglich an die neue Website Struktur angepasst.
Noch ein Dank an alle die das Skript erstellt und Verbesserungen eingebracht haben!Hier meine angepasste Version zum neuen Seitenlayout von Wetteronline:
// ######################################################################################################## // Polleninfo auswerten heute und die nächsten Tage // Angepasste Version von Spike - Vielen Dank an steinwedel, pix, robsdobs, und wer noch so dran war :) // basierend auf Original Version 1.52 -> angepasste Version 1.0 - 15.03.2019 // ######################################################################################################## // @ts-check "use strict"; ///< script> var exports = {}; < / script> /************************************************************************************************** * Initiale Optionen **************************************************************************************************/ //Welcher Ort soll abgefragt werden? var baseUrl: string = "https://www.wetteronline.de/pollen/hierdeinenStadtnamenrein"; //Wo sollen die Daten unter javascript.0... abgelegt werden? var baseObjPath: string = 'wetter.pollenvorhersage'; /************************************************************************************************** * Globale TypeScript Definitionen **************************************************************************************************/ interface iRequestOptions { url: string; headers: any; } /** * Function for check if a object is a primitive object (string, number, etc) * @param obj any object to check if it is a primitive object * @returns boolean which is true if object in parameter is a primitive object */ function isPrimitive(obj:any):boolean { return (obj !== Object(obj)); } /** * write any objects given as parameter to log as debug * @param param a nist of different objects */ function logDebug(...param: any[]):void { if (arguments.length > 0) { var text:string[] = []; for (var i = 0; i < arguments.length; i++) { if (typeof arguments[i] === 'string' || arguments[i] instanceof String) { text.push(arguments[i]); } else if(arguments[i] === null) { text.push('null'); } else if(arguments[i] === undefined) { text.push('undefined'); } else if (isPrimitive(arguments[i])) { text.push(arguments[i]); } else { text.push(JSON.stringify(arguments[i])); } //enum close bracket cannot be found in "channel[state.id=*.TEMPERATURE](rooms=WZ|Wohnung|Wohnzimmer" } log(text.join(' '), 'debug'); } } /** * write any objects given as parameter to log as Information * @param param a nist of different objects */ function logInfo(...param: any[]):void { if (arguments.length > 0) { var text:string[] = []; for (var i = 0; i < arguments.length; i++) { if (typeof arguments[i] === 'string' || arguments[i] instanceof String) { text.push(arguments[i]); } else if(arguments[i] === null) { text.push('null'); } else if(arguments[i] === undefined) { text.push('undefined'); } else if (isPrimitive(arguments[i])) { text.push(arguments[i]); } else { text.push(JSON.stringify(arguments[i])); } //enum close bracket cannot be found in "channel[state.id=*.TEMPERATURE](rooms=WZ|Wohnung|Wohnzimmer" } log(text.join(' '), 'info'); setState('javascript.' + instance + '.Ereignisliste.event','INFO|'+text.join(' ')); } //logEnhanced(logtext, 'info'); //console.debug(p); //logs(logtext,loglevels.debug); } /** * write any objects given as parameter to log as warning * @param param a nist of different objects */ function logWarning(...param: any[]):void { if (arguments.length > 0) { var text:string[] = []; for (var i = 0; i < arguments.length; i++) { if (typeof arguments[i] === 'string' || arguments[i] instanceof String) { text.push(arguments[i]); } else if(arguments[i] === null) { text.push('null'); } else if(arguments[i] === undefined) { text.push('undefined'); } else if (isPrimitive(arguments[i])) { text.push(arguments[i]); } else { text.push(JSON.stringify(arguments[i])); } //enum close bracket cannot be found in "channel[state.id=*.TEMPERATURE](rooms=WZ|Wohnung|Wohnzimmer" } log(text.join(' '), 'warn'); setState('javascript.' + instance + '.Ereignisliste.event','WARN|'+text.join(' ')); } //logEnhanced(logtext, 'warn'); //console.warn(p); //logs(logtext,loglevels.warn); } /** * write any objects given as parameter to log as error * @param param a nist of different objects */ function logError(...param: any[]):void { if (arguments.length > 0) { var text:string[] = []; for (var i = 0; i < arguments.length; i++) { if (typeof arguments[i] === 'string' || arguments[i] instanceof String) { text.push(arguments[i]); } else if(arguments[i] === null) { text.push('null'); } else if(arguments[i] === undefined) { text.push('undefined'); } else if (isPrimitive(arguments[i])) { text.push(arguments[i]); } else { text.push(JSON.stringify(arguments[i])); } //enum close bracket cannot be found in "channel[state.id=*.TEMPERATURE](rooms=WZ|Wohnung|Wohnzimmer" } log(text.join(' '), 'error'); setState('javascript.' + instance + '.Ereignisliste.event','ERROR|'+text.join(' ')); } } /************************************************************************************************** * Lokale TypeScript Definitionen **************************************************************************************************/ //import request = require("request"); var Pollenarten:string[] = ['Erle','Hasel','Pappel','Weide','Ulme','Birke','Buche','Ampfer','Roggen','Gräser','Eiche','Wegerich','Beifuß','Ambrosia']; var tageVorhersage = ['d0','d1','d2','d3','d4','d5','d6']; var tageVorhersageName = ['heute','morgen','übermorgen','heute + 3','heute + 4','heute + 5','heute + 6']; function stripTags(data:string):string { return data.replace(/( |<([^>]+)>)/ig, ""); } function getDate(days: number): string { // Eingabe 0, 1, 2, ... var jetzt = new Date(); jetzt.setHours(0); jetzt.setMinutes(0); jetzt.setSeconds(0); jetzt.setMilliseconds(0); var newdate = new Date(); newdate.setTime(jetzt.getTime() + (24 * 60 * 60 * 1000 * days) ); // heute + anzahl tage ins Millisekunden var date :string = newdate.getDate().toString(); var month: string = (newdate.getMonth()+1).toString(); var year: string = newdate.getFullYear().toString(); date = (date.length < 2) ? '0' + date : date; month = (month.length < 2) ? '0' + month : month; var result:string = year+month+date; logDebug('Datum in Link: ', result); return (result); // Ausgabe z.B. 20160506 } function GetPollenIndex(pflanze:string, html:string, day:number):number { var code ={'noburden':0, 'weakburden':1, 'moderateburden':2, 'strongburden':3}; var result:string= ""; var start:number =html.indexOf(pflanze)+pflanze.length; html=html.slice(start); start = html.indexOf('data-day' + day); html=html.slice(start); var ende:number =html.indexOf("burden") + 6; result=html.substring(0,ende).replace("data-day" + day + '="',""); result=result.trim(); return code[result]; } function initializePollenwetter(baseObj:string, name:string):void { createState(baseObj, '', false, { name: name, type: "string", role: 'json', desc: 'Pollenflug', read: true, write: false}); for(let i=0;i<Pollenarten.length;i++) { createState(baseObj + '.' + Pollenarten[i].toLowerCase(), 0, false, { name: 'Pollenart '+ Pollenarten[i], type: "number", role: 'value', desc: 'Pollenart ' + Pollenarten[i], read: true, write: false}); } createState(baseObj+'.count.gt0', 0, false, { name: 'Anzahl Pollen größer 0', type: "number", role: 'value', desc: 'Anzahl Pollen', read: true, write: false}); for(let i=0;i<4;i++) { createState(baseObj+'.text.'+i.toString(), '', false, { name: 'Liste Pollen größern ' + String(i), type: "string", role: 'text', desc: 'Pollenübersicht', read: true, write: false}); createState(baseObj+'.html.'+i.toString(), '', false, { name: 'Liste Pollen größern ' + String(i) + ' (html)', type: "string", role: 'html', desc: 'Pollenübersicht', read: true, write: false}); createState(baseObj+'.count.'+i.toString(), 0, false, { name: 'Anzahl Pollen mit ' + String(i), type: "number", role: 'value', desc: 'Anzahl Pollen', read: true, write: false}); } } /* function removeOldPollenwetter():void { for(var i=0;i<Pollenarten.length;i++) { deleteState(baseObjPath + '.' + Pollenarten[i].toLowerCase()); } } */ function readPollenwetterForAllDays():void { //logDebug("Start",day,baseObj); try { var options:iRequestOptions = { url: baseUrl, headers: { 'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.1' } }; //log(options.url); request(options, function (error, response, body):void { if (!error && response.statusCode == 200) { // kein Fehler, Inhalt in body body=body.replace(/\t/g, ' '); body=body.replace(/(\n|\r)/g, ''); var start:number =body.indexOf('text">Erle</div>'); var ende:number =body.indexOf('id="burden_icons_legend_headline">'); if (start>-1) { body=body.substring(start, ende); } let pobj:any = {}; let pot = ['','','','']; let poh = ['','','','']; let poc = [0,0,0,0]; let cnt =0; for(let day=0;day<tageVorhersage.length;day++) { let baseObj: string = baseObjPath + '.' + tageVorhersage[day]; initializePollenwetter(baseObj, tageVorhersageName[day]); for(let i=0;i<Pollenarten.length;i++) { let pi:number = GetPollenIndex(Pollenarten[i],body, day); pobj[Pollenarten[i].toLowerCase()] = pi; if (pi>0) { cnt++; } poc[pi]++; pot[pi] = pot[pi] + Pollenarten[i] + '\r\n'; poh[pi] = poh[pi] + Pollenarten[i] + '<br/>'; setState(baseObj+'.'+Pollenarten[i].toLowerCase(),pi); } setState(baseObj+'.count.gt0',cnt); for(let i=0;i<4;i++) { setState(baseObj+'.text.'+i.toString(),pot[i]); setState(baseObj+'.html.'+i.toString(),poh[i]); setState(baseObj+'.count.'+i.toString(),poc[i]); } setState(baseObj,JSON.stringify(pobj)); } } else { logInfo("StatusCode="+response.statusCode); logError(error); // Error beim Einlesen } }); } catch (e) { logError('Fehler (try) leseWebseite: ' + e); } } function readPollenwetter() { readPollenwetterForAllDays(); } //removeOldPollenwetter(); readPollenwetter(); /* # * * * * * command to execute # ¦ ¦ ¦ ¦ ¦ # ¦ ¦ ¦ ¦ ¦ # ¦ ¦ ¦ ¦ +----- day of week (0 - 6) (0 to 6 are Sunday to Saturday, or use names; 7 is Sunday, the same as 0) # ¦ ¦ ¦ +---------- month (1 - 12) # ¦ ¦ +--------------- day of month (1 - 31) # ¦ +-------------------- hour (0 - 23) # +------------------------- min (0 - 59) */ schedule("5 0 * * *", readPollenwetter);
Denkt dran, eure Stadt wieder einzutragen und evtl. wohin ihr die Daten hinschreiben wollt. Findet ihr gleich unter "Initiale Optionen"..
Viel Spaß damit und ein schönes Wochenende!
-
14:15:48.050 info javascript.0 Stop script script.js.Test.Pollenflug 14:15:48.070 info javascript.0 Start javascript script.js.Test.Pollenflug 14:15:48.070 error javascript.0 script.js.Test.Pollenflug compile failed: at script.js.Test.Pollenflug:14
EDIT: Ist ja ein TS!