Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Wunsch: Pollenflug-(Adapter/wasauchimmer)

    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

    Wunsch: Pollenflug-(Adapter/wasauchimmer)

    This topic has been deleted. Only users with topic management privileges can see it.
    • Homoran
      Homoran Global Moderator Administrators @Segway last edited by Homoran

      @Segway nein als user pi mit

      sudo -H npm install -g npm
      
      Segway 1 Reply Last reply Reply Quote 0
      • Segway
        Segway @Homoran last edited by Segway

        @Homoran

        Update hm-rega from @2.3.1 to @2.3.2
        NPM version: 6.9.0
        

        👍 👍 👍☺ ☺ ☺

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

          Hallo
          Hatte das Skript das ganze letzte Jahr am laufen

          ```
          // ########################################################################################################
          // Polleninfo auswerten heute und die nächsten Tage
          // Version 1.4
          // ########################################################################################################

          /**************************************************************************************************

          • Initiale Optionen
            **************************************************************************************************/
            interface iRequestOptions {
            url: string;
            headers: any;
            }

          var baseUrl: string = "https://www.wetteronline.de/pollen/perg";
          var baseObjPath: string = 'wetter.pollenvorhersage';

          /**************************************************************************************************

          • Globale TypeScript Definitionen
            *************************************************************************************************/
            // -----------------------------------------------------------------------------
            /
            Die folgenden Funktionen sind bei mir in einem globalen script.
            Wenn man diese global definieren will, muss man das lokal referenzieren mit:
            declare function isPrimitive(obj:any):boolean
            declare function logDebug(...param: any[]):void;
            declare function logInfo(...param: any[]):void;
            declare function logWarning(...param: any[]):void;
            declare function logError(...param: any[]):void;
            */

          /**

          • 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.0.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.0.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.0.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'];
          var tageVorhersageName = ['heute','morgen','übermorgen','heute + 3','heute + 4','heute + 5'];

          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):number {
          var code ={'kein':0, 'schwach':1, 'mäßig':2, 'stark':3};
          var result:string= "";
          var start:number =html.indexOf(pflanze)+pflanze.length;

          result=html.slice(start);
          result=result.trim();
          

          //logDebug('result for ',pflanze,html.slice(0,600));
          var stop:number =result.indexOf(' ');
          result=result.slice(0,stop);
          logDebug('pflanze=',pflanze,'code=',result);
          return code[result];
          }

          function initializePollenwetter(baseObj:string, name:string):void {
          createState(baseObj,0,false, {
          name: name,
          type: "string",
          role: 'json',
          read: true,
          write: false});

          for(var i=0;i<Pollenarten.length;i++) {
            createState(baseObj + '.' + Pollenarten[i].toLowerCase(),0,false, {
               name: 'Pollenart '+ Pollenarten[i],
               type: "number",
               role: 'value',
               read: true,
               write: false});
          }
          

          }

          function removeOldPollenwetter():void {
          for(var i=0;i<Pollenarten.length;i++) {
          deleteState(baseObjPath + '.' + Pollenarten[i].toLowerCase());
          }
          }

          function readPollenwetterForDay(day:number, baseObj:string):void {
          logDebug("Start");
          try {
          var options:iRequestOptions = {
          url: ((day>0) ? baseUrl + '?fcdatstr=' + getDate(day) : baseUrl), // korrekten Link erstellen ,
          headers: {
          'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:40.0) Gecko/20100101 Firefox/40.1'
          }
          };
          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('<ul id="pollentable">');
          if (start>-1) { body=body.slice(start); }
          body=stripTags(body);
          //logDebug('body',body);
          let pobj:any = {};
          for(let i=0;i<Pollenarten.length;i++) {
          let pi:number = GetPollenIndex(Pollenarten[i],body);
          pobj[Pollenarten[i].toLowerCase()] = pi;
          setState(baseObj+'.'+Pollenarten[i].toLowerCase(),pi);
          }
          setState(baseObj,JSON.stringify(pobj));
          } else {
          logInfo("StatusCode="+response.statusCode);
          logError(error); // Error beim Einlesen
          }
          });
          } catch (e) {
          logError('Fehler (try) leseWebseite: ' + e);
          }
          }

          function readPollenwetter() {
          for (let d:number = 0; d < tageVorhersage.length; d++) {
          let path: string = baseObjPath + '.' + tageVorhersage[d];
          initializePollenwetter(path, tageVorhersageName[d]);
          readPollenwetterForDay(d, path);
          }
          }

          removeOldPollenwetter();
          readPollenwetter();
          schedule("5 0 * * *", readPollenwetter);

          nun nach dem Winter habe ich es wieder gestartet!
          nun gleich einen ERROR
          [s=]```
          20:20:23.749	error	javascript.0 script.js.common.Polleninfo compile failed:
           at script.js.common.Polleninfo:9
          ```[/s]
          Das 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
          1 Reply Last reply Reply Quote 0
          • SmarthomeMF
            SmarthomeMF last edited by

            nun nach dem Winter habe ich es wieder gestartet!
            nun gleich einen ERROR

            20:20:23.749 error javascript.0 script.js.common.Polleninfo compile failed:
            at script.js.common.Polleninfo:9

            Das 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

            1 Reply Last reply Reply Quote 0
            • SBorg
              SBorg Forum Testing Most Active last edited by

              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...

              Homoran 1 Reply Last reply Reply Quote 0
              • Homoran
                Homoran Global Moderator Administrators @SBorg last edited by Homoran

                @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 vorbereitet

                Mit 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

                SBorg AlCalzone 2 Replies Last reply Reply Quote 0
                • SBorg
                  SBorg Forum Testing Most Active @Homoran last edited by

                  @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.

                  1 Reply Last reply Reply Quote 0
                  • AlCalzone
                    AlCalzone Developer @Homoran last edited by

                    @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

                    1 Reply Last reply Reply Quote 0
                    • SBorg
                      SBorg Forum Testing Most Active last edited by

                      @Homoran meinte aber IMO beim Parser-Adapter...?

                      Homoran 1 Reply Last reply Reply Quote 0
                      • Homoran
                        Homoran Global Moderator Administrators @SBorg last edited by

                        @SBorg
                        So ist es

                        1 Reply Last reply Reply Quote 0
                        • AlCalzone
                          AlCalzone Developer last edited by

                          Ok da bin ich raus 😓

                          Homoran 1 Reply Last reply Reply Quote 0
                          • Homoran
                            Homoran Global Moderator Administrators @AlCalzone last edited by

                            @AlCalzone
                            und ich bei einem Skript 😉

                            1 Reply Last reply Reply Quote 0
                            • SBorg
                              SBorg Forum Testing Most Active last edited by

                              Wie sehr willst du es denn? 😇
                              Out-of-the-box kann ich dir höchstens mein Shell-Script anbieten:
                              Pollen.png
                              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.

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

                                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(/(&nbsp;|<([^>]+)>)/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!

                                sigi234 Homoran 3 Replies Last reply Reply Quote 1
                                • sigi234
                                  sigi234 Forum Testing Most Active @SpikeNbg last edited by sigi234

                                  @SpikeNbg

                                  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!

                                  SpikeNbg 1 Reply Last reply Reply Quote 0
                                  • Homoran
                                    Homoran Global Moderator Administrators @SpikeNbg last edited by

                                    @SpikeNbg
                                    Danke erst einmal, bei mir kommen Ergebnisse, aber auch ganz viele:

                                    19:15:04.737	warn	javascript.0 at Request._callback (script.js.Wetter_und_Klima.Pollenskript_neu:296:25)
                                    
                                    SpikeNbg 1 Reply Last reply Reply Quote 0
                                    • SpikeNbg
                                      SpikeNbg @Homoran last edited by SpikeNbg

                                      @Homoran

                                      von diesen Warnings hatte ich mit der alten Version des Skripts ganz viele, im Endeffekt genau so viele wie er Werte gesetzt hat.
                                      Ich hab dann mal die alte Struktur komplett gelöscht und vom neuen Skript (automatisch) wieder neu anlegen lassen. Danach kamen sie nicht mehr..

                                      Stimmen denn die Ergebnisse in der Objektstruktur? (müsstest du mit der Webseite vergleichen)

                                      Homoran 1 Reply Last reply Reply Quote 0
                                      • SpikeNbg
                                        SpikeNbg @sigi234 last edited by

                                        @sigi234

                                        Hi! Ja genau, ist ein TypeScript

                                        1 Reply Last reply Reply Quote 0
                                        • Homoran
                                          Homoran Global Moderator Administrators @SpikeNbg last edited by

                                          @SpikeNbg

                                          ich habe gerade mal im log nachgesehen, da steht dann noch u.a. (von unten nach oben):

                                          javascript.0	2019-03-15 19:15:04.563	warn	at Request._callback (script.js.Wetter_und_Klima.Pollenskript_neu:296:25)
                                          javascript.0	2019-03-15 19:15:04.563	warn	at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1258:20)
                                          javascript.0	2019-03-15 19:15:04.563	warn	Wrong type of javascript.0.wetter.neu.pollenvorhersage.d6.ambrosia: "undefined". Please fix, while deprecated and will not work in next versions.
                                          

                                          ich habe alle States neu anlegen lassen, in einem neuen Pfad

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

                                            Hab den Fehler.. Es gibt jetzt nur noch 6 Tage, nicht mehr 7. (also d0 bis d5, früher d0 bis d6)

                                            Danke fürs Bescheid geben, komisch nur, dass ich die Warnings heute Mittag nicht gesehen hab 😇

                                            Hier ist die Version 1.1:

                                            // ########################################################################################################
                                            // 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.1 - 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'];
                                            var tageVorhersageName = ['heute','morgen','übermorgen','heute + 3','heute + 4','heute + 5','heute + 6'];
                                             
                                            function stripTags(data:string):string {
                                            	return data.replace(/(&nbsp;|<([^>]+)>)/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, '':0}; 
                                            	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();
                                            	// log("Pflanze: " + pflanze + ", Tag: " + day + ": "  + result + " > " + code[result]);
                                            	
                                            	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);
                                            
                                            
                                            Homoran Nashra F 3 Replies Last reply Reply Quote 1
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate
                                            FAQ Cloud / IOT
                                            HowTo: Node.js-Update
                                            HowTo: Backup/Restore
                                            Downloads
                                            BLOG

                                            779
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            43
                                            266
                                            43825
                                            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