Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Wunsch: Pollenflug-(Adapter/wasauchimmer)

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.8k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.2k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    3.2k

Wunsch: Pollenflug-(Adapter/wasauchimmer)

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
266 Beiträge 43 Kommentatoren 53.9k Aufrufe 19 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • HomoranH 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

    AlCalzoneA Offline
    AlCalzoneA Offline
    AlCalzone
    Developer
    schrieb am zuletzt editiert von
    #219

    @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

    Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

    1 Antwort Letzte Antwort
    0
    • SBorgS Offline
      SBorgS Offline
      SBorg
      Forum Testing Most Active
      schrieb am zuletzt editiert von
      #220

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

      LG SBorg ( SBorg auf GitHub)
      Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

      HomoranH 1 Antwort Letzte Antwort
      0
      • SBorgS SBorg

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

        HomoranH Nicht stören
        HomoranH Nicht stören
        Homoran
        Global Moderator Administrators
        schrieb am zuletzt editiert von
        #221

        @SBorg
        So ist es

        kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

        1 Antwort Letzte Antwort
        0
        • AlCalzoneA Offline
          AlCalzoneA Offline
          AlCalzone
          Developer
          schrieb am zuletzt editiert von
          #222

          Ok da bin ich raus :sweat:

          Warum `sudo` böse ist: https://forum.iobroker.net/post/17109

          HomoranH 1 Antwort Letzte Antwort
          0
          • AlCalzoneA AlCalzone

            Ok da bin ich raus :sweat:

            HomoranH Nicht stören
            HomoranH Nicht stören
            Homoran
            Global Moderator Administrators
            schrieb am zuletzt editiert von
            #223

            @AlCalzone
            und ich bei einem Skript ;-)

            kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

            Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

            der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

            1 Antwort Letzte Antwort
            0
            • SBorgS Offline
              SBorgS Offline
              SBorg
              Forum Testing Most Active
              schrieb am zuletzt editiert von
              #224

              Wie sehr willst du es denn? :innocent:
              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.

              LG SBorg ( SBorg auf GitHub)
              Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

              1 Antwort Letzte Antwort
              0
              • SpikeNbgS Offline
                SpikeNbgS Offline
                SpikeNbg
                schrieb am zuletzt editiert von
                #225

                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! :+1:

                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!

                sigi234S HomoranH 3 Antworten Letzte Antwort
                1
                • SpikeNbgS SpikeNbg

                  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! :+1:

                  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!

                  sigi234S Online
                  sigi234S Online
                  sigi234
                  Forum Testing Most Active
                  schrieb am zuletzt editiert von sigi234
                  #226

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

                  Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                  Immer Daten sichern!

                  SpikeNbgS 1 Antwort Letzte Antwort
                  0
                  • SpikeNbgS SpikeNbg

                    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! :+1:

                    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!

                    HomoranH Nicht stören
                    HomoranH Nicht stören
                    Homoran
                    Global Moderator Administrators
                    schrieb am zuletzt editiert von
                    #227

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

                    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                    SpikeNbgS 1 Antwort Letzte Antwort
                    0
                    • HomoranH Homoran

                      @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)
                      
                      SpikeNbgS Offline
                      SpikeNbgS Offline
                      SpikeNbg
                      schrieb am zuletzt editiert von SpikeNbg
                      #228

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

                      HomoranH 1 Antwort Letzte Antwort
                      0
                      • sigi234S 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!

                        SpikeNbgS Offline
                        SpikeNbgS Offline
                        SpikeNbg
                        schrieb am zuletzt editiert von
                        #229

                        @sigi234

                        Hi! Ja genau, ist ein TypeScript

                        1 Antwort Letzte Antwort
                        0
                        • SpikeNbgS 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)

                          HomoranH Nicht stören
                          HomoranH Nicht stören
                          Homoran
                          Global Moderator Administrators
                          schrieb am zuletzt editiert von
                          #230

                          @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

                          kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                          Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                          der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                          1 Antwort Letzte Antwort
                          0
                          • SpikeNbgS Offline
                            SpikeNbgS Offline
                            SpikeNbg
                            schrieb am zuletzt editiert von
                            #231

                            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 :innocent:

                            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);
                            
                            
                            HomoranH NashraN F 3 Antworten Letzte Antwort
                            1
                            • SpikeNbgS SpikeNbg

                              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 :innocent:

                              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);
                              
                              
                              HomoranH Nicht stören
                              HomoranH Nicht stören
                              Homoran
                              Global Moderator Administrators
                              schrieb am zuletzt editiert von
                              #232

                              @SpikeNbg
                              Super!
                              läuft.
                              Bei der ersten Runde kommen die Fehler noch - war auch zu erwarten, danach läuft's sauber durch.

                              @SpikeNbg sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):

                              komisch nur, dass ich die Warnings heute Mittag nicht gesehen hab

                              Vielleicht haben die eben erst die Seite geändert.
                              Sigi hatte ja auch keine Fehler! )oder?)

                              kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                              Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                              der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                              sigi234S 1 Antwort Letzte Antwort
                              0
                              • SmarthomeMFS Offline
                                SmarthomeMFS Offline
                                SmarthomeMF
                                schrieb am zuletzt editiert von
                                #233

                                Hallo
                                und danke für die arbeit.

                                Habe das Skript am laufen bekomme aber eine menge error!

                                javascript.0	2019-03-15 19:52:38.602	error	at TCP.onread (net.js:601:20)
                                javascript.0	2019-03-15 19:52:38.602	error	at Socket.Readable.push (_stream_readable.js:208:10)
                                javascript.0	2019-03-15 19:52:38.602	error	at readableAddChunk (_stream_readable.js:250:11)
                                javascript.0	2019-03-15 19:52:38.602	error	at addChunk (_stream_readable.js:263:12)
                                javascript.0	2019-03-15 19:52:38.602	error	at Socket.emit (events.js:211:7)
                                javascript.0	2019-03-15 19:52:38.602	error	at emitOne (events.js:116:13)
                                javascript.0	2019-03-15 19:52:38.602	error	at Socket.realHandler (/opt/iobroker/node_modules/ws/lib/WebSocket.js:825:20)
                                javascript.0	2019-03-15 19:52:38.602	error	at Receiver.add (/opt/iobroker/node_modules/ws/lib/Receiver.js:103:24)
                                javascript.0	2019-03-15 19:52:38.602	error	at Receiver.expectHandler (/opt/iobroker/node_modules/ws/lib/Receiver.js:499:31)
                                javascript.0	2019-03-15 19:52:38.602	error	at Receiver.finish (/opt/iobroker/node_modules/ws/lib/Receiver.js:541:12)
                                javascript.0	2019-03-15 19:52:38.602	error	at Receiver.flush (/opt/iobroker/node_modules/ws/lib/Receiver.js:347:3)
                                javascript.0	2019-03-15 19:52:38.602	error	at /opt/iobroker/node_modules/ws/lib/Receiver.js:508:14
                                javascript.0	2019-03-15 19:52:38.602	error	at Receiver.applyExtensions (/opt/iobroker/node_modules/ws/lib/Receiver.js:371:5)
                                javascript.0	2019-03-15 19:52:38.602	error	at /opt/iobroker/node_modules/ws/lib/Receiver.js:536:18
                                javascript.0	2019-03-15 19:52:38.602	error	at Receiver.ontext (/opt/iobroker/node_modules/ws/lib/WebSocket.js:841:10)
                                javascript.0	2019-03-15 19:52:38.602	error	at WebSocket.emit (events.js:214:7)
                                javascript.0	2019-03-15 19:52:38.602	error	at emitTwo (events.js:126:13)
                                javascript.0	2019-03-15 19:52:38.602	error	at WebSocket.onMessage (/opt/iobroker/node_modules/ws/lib/WebSocket.js:442:14)
                                javascript.0	2019-03-15 19:52:38.602	error	at WebSocket.ws.onmessage (/opt/iobroker/node_modules/engine.io-client/lib/transports/websocket.js:146:10)
                                javascript.0	2019-03-15 19:52:38.602	error	at WS.Transport.onData (/opt/iobroker/node_modules/engine.io-client/lib/transport.js:137:8)
                                javascript.0	2019-03-15 19:52:38.602	error	at WS.Transport.onPacket (/opt/iobroker/node_modules/engine.io-client/lib/transport.js:145:8)
                                javascript.0	2019-03-15 19:52:38.602	error	at WS.Emitter.emit (/opt/iobroker/node_modules/engine.io-client/node_modules/component-emitter/index.js:133:20)
                                javascript.0	2019-03-15 19:52:38.602	error	at WS.<anonymous> (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:268:10)
                                javascript.0	2019-03-15 19:52:38.602	error	at Socket.onPacket (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:451:14)
                                javascript.0	2019-03-15 19:52:38.602	error	at Socket.Emitter.emit (/opt/iobroker/node_modules/engine.io-client/node_modules/component-emitter/index.js:133:20)
                                javascript.0	2019-03-15 19:52:38.601	error	at Socket.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                javascript.0	2019-03-15 19:52:38.601	error	at Manager.ondata (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:322:16)
                                javascript.0	2019-03-15 19:52:38.601	error	at Decoder.add (/opt/iobroker/node_modules/socket.io-parser/index.js:246:12)
                                javascript.0	2019-03-15 19:52:38.601	error	at Decoder.Emitter.emit (/opt/iobroker/node_modules/component-emitter/index.js:134:20)
                                javascript.0	2019-03-15 19:52:38.601	error	at Decoder.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                javascript.0	2019-03-15 19:52:38.601	error	at Manager.ondecoded (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:332:8)
                                javascript.0	2019-03-15 19:52:38.601	error	at Manager.Emitter.emit (/opt/iobroker/node_modules/socket.io-client/node_modules/component-emitter/index.js:133:20)
                                javascript.0	2019-03-15 19:52:38.601	error	at Manager.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                javascript.0	2019-03-15 19:52:38.601	error	at Socket.onpacket (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:236:12)
                                javascript.0	2019-03-15 19:52:38.601	error	at Socket.onack (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:312:9)
                                javascript.0	2019-03-15 19:52:38.601	error	at Socket.adapter.getForeignState (/opt/iobroker/node_modules/iobroker.javascript/main.js:745:17)
                                javascript.0	2019-03-15 19:52:38.601	error	at createProblemObject (/opt/iobroker/node_modules/iobroker.javascript/main.js:1123:17)
                                javascript.0	2019-03-15 19:52:38.601	error	at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1070:37)
                                javascript.0	2019-03-15 19:52:38.601	error	at compile (/opt/iobroker/node_modules/iobroker.javascript/main.js:878:28)
                                javascript.0	2019-03-15 19:52:38.601	error	at Object.createScript (vm.js:80:10)
                                javascript.0	2019-03-15 19:52:38.601	error	SyntaxError: Unexpected token :
                                javascript.0	2019-03-15 19:52:38.601	error	^
                                javascript.0	2019-03-15 19:52:38.601	error	var baseUrl: string = "https://www.wetteronline.de/pollen/perg";
                                javascript.0	2019-03-15 19:52:38.601	error	at script.js.common.Polleninfo_2:14
                                javascript.0	2019-03-15 19:52:38.601	error	script.js.common.Polleninfo_2 compile failed:
                                

                                was passt da nicht?
                                Danke

                                Max

                                ioBroker auf einem NUC ,16GB RAM, 120GB SSD) mit Proxmox
                                Cloud Pro, iot, Alexa, Sonos, sonoff, Fronius, Harmony, Doorbird, Shelly, Hue, Loxone, Mihome, …

                                HomoranH 1 Antwort Letzte Antwort
                                0
                                • SmarthomeMFS SmarthomeMF

                                  Hallo
                                  und danke für die arbeit.

                                  Habe das Skript am laufen bekomme aber eine menge error!

                                  javascript.0	2019-03-15 19:52:38.602	error	at TCP.onread (net.js:601:20)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Socket.Readable.push (_stream_readable.js:208:10)
                                  javascript.0	2019-03-15 19:52:38.602	error	at readableAddChunk (_stream_readable.js:250:11)
                                  javascript.0	2019-03-15 19:52:38.602	error	at addChunk (_stream_readable.js:263:12)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Socket.emit (events.js:211:7)
                                  javascript.0	2019-03-15 19:52:38.602	error	at emitOne (events.js:116:13)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Socket.realHandler (/opt/iobroker/node_modules/ws/lib/WebSocket.js:825:20)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Receiver.add (/opt/iobroker/node_modules/ws/lib/Receiver.js:103:24)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Receiver.expectHandler (/opt/iobroker/node_modules/ws/lib/Receiver.js:499:31)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Receiver.finish (/opt/iobroker/node_modules/ws/lib/Receiver.js:541:12)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Receiver.flush (/opt/iobroker/node_modules/ws/lib/Receiver.js:347:3)
                                  javascript.0	2019-03-15 19:52:38.602	error	at /opt/iobroker/node_modules/ws/lib/Receiver.js:508:14
                                  javascript.0	2019-03-15 19:52:38.602	error	at Receiver.applyExtensions (/opt/iobroker/node_modules/ws/lib/Receiver.js:371:5)
                                  javascript.0	2019-03-15 19:52:38.602	error	at /opt/iobroker/node_modules/ws/lib/Receiver.js:536:18
                                  javascript.0	2019-03-15 19:52:38.602	error	at Receiver.ontext (/opt/iobroker/node_modules/ws/lib/WebSocket.js:841:10)
                                  javascript.0	2019-03-15 19:52:38.602	error	at WebSocket.emit (events.js:214:7)
                                  javascript.0	2019-03-15 19:52:38.602	error	at emitTwo (events.js:126:13)
                                  javascript.0	2019-03-15 19:52:38.602	error	at WebSocket.onMessage (/opt/iobroker/node_modules/ws/lib/WebSocket.js:442:14)
                                  javascript.0	2019-03-15 19:52:38.602	error	at WebSocket.ws.onmessage (/opt/iobroker/node_modules/engine.io-client/lib/transports/websocket.js:146:10)
                                  javascript.0	2019-03-15 19:52:38.602	error	at WS.Transport.onData (/opt/iobroker/node_modules/engine.io-client/lib/transport.js:137:8)
                                  javascript.0	2019-03-15 19:52:38.602	error	at WS.Transport.onPacket (/opt/iobroker/node_modules/engine.io-client/lib/transport.js:145:8)
                                  javascript.0	2019-03-15 19:52:38.602	error	at WS.Emitter.emit (/opt/iobroker/node_modules/engine.io-client/node_modules/component-emitter/index.js:133:20)
                                  javascript.0	2019-03-15 19:52:38.602	error	at WS.<anonymous> (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:268:10)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Socket.onPacket (/opt/iobroker/node_modules/engine.io-client/lib/socket.js:451:14)
                                  javascript.0	2019-03-15 19:52:38.602	error	at Socket.Emitter.emit (/opt/iobroker/node_modules/engine.io-client/node_modules/component-emitter/index.js:133:20)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Socket.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Manager.ondata (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:322:16)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Decoder.add (/opt/iobroker/node_modules/socket.io-parser/index.js:246:12)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Decoder.Emitter.emit (/opt/iobroker/node_modules/component-emitter/index.js:134:20)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Decoder.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Manager.ondecoded (/opt/iobroker/node_modules/socket.io-client/lib/manager.js:332:8)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Manager.Emitter.emit (/opt/iobroker/node_modules/socket.io-client/node_modules/component-emitter/index.js:133:20)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Manager.<anonymous> (/opt/iobroker/node_modules/component-bind/index.js:21:15)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Socket.onpacket (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:236:12)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Socket.onack (/opt/iobroker/node_modules/socket.io-client/lib/socket.js:312:9)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Socket.adapter.getForeignState (/opt/iobroker/node_modules/iobroker.javascript/main.js:745:17)
                                  javascript.0	2019-03-15 19:52:38.601	error	at createProblemObject (/opt/iobroker/node_modules/iobroker.javascript/main.js:1123:17)
                                  javascript.0	2019-03-15 19:52:38.601	error	at prepareScript (/opt/iobroker/node_modules/iobroker.javascript/main.js:1070:37)
                                  javascript.0	2019-03-15 19:52:38.601	error	at compile (/opt/iobroker/node_modules/iobroker.javascript/main.js:878:28)
                                  javascript.0	2019-03-15 19:52:38.601	error	at Object.createScript (vm.js:80:10)
                                  javascript.0	2019-03-15 19:52:38.601	error	SyntaxError: Unexpected token :
                                  javascript.0	2019-03-15 19:52:38.601	error	^
                                  javascript.0	2019-03-15 19:52:38.601	error	var baseUrl: string = "https://www.wetteronline.de/pollen/perg";
                                  javascript.0	2019-03-15 19:52:38.601	error	at script.js.common.Polleninfo_2:14
                                  javascript.0	2019-03-15 19:52:38.601	error	script.js.common.Polleninfo_2 compile failed:
                                  

                                  was passt da nicht?
                                  Danke

                                  HomoranH Nicht stören
                                  HomoranH Nicht stören
                                  Homoran
                                  Global Moderator Administrators
                                  schrieb am zuletzt editiert von
                                  #234

                                  @SmarthomeMF

                                  Das ist kein javascript sondern ein TypeScript

                                  kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                                  Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                  der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                                  1 Antwort Letzte Antwort
                                  0
                                  • SmarthomeMFS Offline
                                    SmarthomeMFS Offline
                                    SmarthomeMF
                                    schrieb am zuletzt editiert von
                                    #235

                                    und dann läuft es...
                                    Danke für die Info....

                                    Max

                                    ioBroker auf einem NUC ,16GB RAM, 120GB SSD) mit Proxmox
                                    Cloud Pro, iot, Alexa, Sonos, sonoff, Fronius, Harmony, Doorbird, Shelly, Hue, Loxone, Mihome, …

                                    1 Antwort Letzte Antwort
                                    0
                                    • HomoranH Homoran

                                      @SpikeNbg
                                      Super!
                                      läuft.
                                      Bei der ersten Runde kommen die Fehler noch - war auch zu erwarten, danach läuft's sauber durch.

                                      @SpikeNbg sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):

                                      komisch nur, dass ich die Warnings heute Mittag nicht gesehen hab

                                      Vielleicht haben die eben erst die Seite geändert.
                                      Sigi hatte ja auch keine Fehler! )oder?)

                                      sigi234S Online
                                      sigi234S Online
                                      sigi234
                                      Forum Testing Most Active
                                      schrieb am zuletzt editiert von sigi234
                                      #236

                                      @Homoran sagte in Wunsch: Pollenflug-(Adapter/wasauchimmer):

                                      Sigi hatte ja auch keine Fehler! )oder?)

                                      Ja doch.........

                                      20:10:25.562	warn	javascript.0 at Request._callback (script.js.Test.Pollenflug:296:25)
                                      

                                      So V 1.1. installiert, am Anfang kamen einige Warnungen, dann nicht mehr. Läuft.

                                      Bitte benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.
                                      Immer Daten sichern!

                                      1 Antwort Letzte Antwort
                                      0
                                      • SpikeNbgS SpikeNbg

                                        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 :innocent:

                                        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);
                                        
                                        
                                        NashraN Offline
                                        NashraN Offline
                                        Nashra
                                        Most Active Forum Testing
                                        schrieb am zuletzt editiert von
                                        #237

                                        @SpikeNbg

                                        Hier ist die Version 1.1:

                                        Vielen Dank, läuft :+1:

                                        Gruß Ralf
                                        Mir egal, wer Dein Vater ist! Wenn ich hier angel, wird nicht übers Wasser gelaufen!!

                                        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                                        1 Antwort Letzte Antwort
                                        0
                                        • SpikeNbgS SpikeNbg

                                          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 :innocent:

                                          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);
                                          
                                          
                                          F Offline
                                          F Offline
                                          Fatmax
                                          schrieb am zuletzt editiert von
                                          #238

                                          @SpikeNbg

                                          Du bist mein Held!
                                          Ein fettes DANKE!

                                          :+1:

                                          Liebe Grüße,
                                          Fatmax

                                          1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

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

                                          361

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe