Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Visualisierung
    4. VIS-Tabelle für WLAN Wetterstation

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    VIS-Tabelle für WLAN Wetterstation

    This topic has been deleted. Only users with topic management privileges can see it.
    • SBorg
      SBorg Forum Testing Most Active @Nashra last edited by

      @nashra Ich kann es halt "leider" nicht testen 😉

      wie üblich ... (der letzte Output genügt)

       if (typeof(formathelp)=="object") {helper=getState(id).val[0];} 
        else if (typeof(formathelp)=="string") { helper=String(getState(id).val);
      console.log(typeof(helper));
      console.log(helper);
                                                 helper=JSON.parse(helper.substring(1, helper.length-1));
      console.log("2nd helper: "+helper);
                                                 }
        else { helper=JSON.parse(getState(id).val); }
      
      liv-in-sky 1 Reply Last reply Reply Quote 0
      • Nashra
        Nashra Most Active Forum Testing last edited by

        @SBorg

        16:11:26.603	info	javascript.0 (430) Start javascript script.js.Wetter.Statistik-tabelle
        16:11:26.630	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle-sborg: registered 2 subscriptions, 1 schedule, 0 messages, 0 logs and 0 file subscriptions
        16:11:26.727	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
        16:11:26.727	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: {"Tiefstwert":8.22,"Hoechstwert":17.72,"Temp_Durchschnitt":13.81,"Max_Windboe":29.45,"Max_Regenmenge":8.1,"Regenmenge_Monat":42.7,"warme_Tage":0,"Sommertage":0,"heisse_Tage":0,"Frost_Tage":0,"kalte_Tage":0,"Eistage":0,"sehr_kalte_Tage":0}
        16:11:26.728	error	javascript.0 (430) script.js.Wetter.Statistik-tabelle: SyntaxError: Unexpected token : in JSON at position 12
        16:11:26.728	error	javascript.0 (430) at script.js.Wetter.Statistik-tabelle:71:56
        16:11:26.728	error	javascript.0 (430) at dataStuff (script.js.Wetter.Statistik-tabelle:56:15)
        16:11:26.729	error	javascript.0 (430) at main (script.js.Wetter.Statistik-tabelle:178:4)
        16:11:45.898	info	javascript.0 (430) Stop script script.js.Wetter.Statistik-tabelle
        
        
        SBorg 1 Reply Last reply Reply Quote 0
        • liv-in-sky
          liv-in-sky @SBorg last edited by

          @sborg

          problem ist -glaube ich - diese zeile :

          helper=JSON.parse(helper.substring(1, (getState(id).val).length-1));
          
          SBorg 1 Reply Last reply Reply Quote 0
          • SBorg
            SBorg Forum Testing Most Active @liv-in-sky last edited by

            @liv-in-sky Jepp, aus irgendeinem Grund entfernt er bei @Nashra beim einlesen die "[]" ich will jetzt per "indexof()" prüfen ob sie drin sind, dann kann ich normal weitermachen oder sie wieder hinzufügen. Nicht schön, aber so funktioniert es für alle...

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

              @nashra

               if (typeof(formathelp)=="object") {helper=getState(id).val[0];} 
                else if (typeof(formathelp)=="string") { helper=String(getState(id).val);
                                                         if (helper.indexOf("[")>=0) { helper=JSON.parse(helper.substring(1, helper.length-1)); }
                                                           else { helper=JSON.parse(helper); }  
                                                         }
                else { helper=JSON.parse(getState(id).val); }
              
              1 Reply Last reply Reply Quote 0
              • Nashra
                Nashra Most Active Forum Testing last edited by Nashra

                gelöscht

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

                  @SBorg

                  16:42:47.832	info	javascript.0 (430) Start javascript script.js.Wetter.Statistik-tabelle
                  16:42:47.849	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: registered 2 subscriptions, 1 schedule, 0 messages, 0 logs and 0 file subscriptions
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: {"Tiefstwert":8.22,"Hoechstwert":17.72,"Temp_Durchschnitt":13.81,"Max_Windboe":29.45,"Max_Regenmenge":8.1,"Regenmenge_Monat":42.7,"warme_Tage":0,"Sommertage":0,"heisse_Tage":0,"Frost_Tage":0,"kalte_Tage":0,"Eistage":0,"sehr_kalte_Tage":0}
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: {"Tiefstwert":-3.72,"Hoechstwert":20.27,"Temp_Durchschnitt":1.03,"Max_Windboe":36.69,"Max_Regenmenge":5.5,"Regenmenge_Monat":20.8,"warme_Tage":5,"Sommertage":0,"heisse_Tage":0,"Frost_Tage":3,"kalte_Tage":8,"Eistage":0,"sehr_kalte_Tage":0}
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: {"Tiefstwert":-4.72,"Hoechstwert":14.61,"Temp_Durchschnitt":9.42,"Max_Windboe":46.02,"Max_Regenmenge":12.9,"Regenmenge_Monat":204.4,"warme_Tage":12,"Sommertage":0,"heisse_Tage":0,"Frost_Tage":13,"kalte_Tage":22,"Eistage":0,"sehr_kalte_Tage":0}
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": -1.77, "Hoechstwert": 12.27, "Temp_Durchschnitt": 2.95, "Max_Windboe": 40.39, "Max_Regenmenge": 22.3, "Regenmenge_Monat": 165.6, "warme_Tage": 0, "Sommertage": 0, "heisse_Tage": 0, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 10, "kalte_Tage": 26, "Eistage": 0, "sehr_kalte_Tage": 0 }
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": -10.61, "Hoechstwert": 20.22, "Temp_Durchschnitt": 4.19, "Max_Windboe": 34.92, "Max_Regenmenge": 27.4, "Regenmenge_Monat": 203.4, "warme_Tage": 1, "Sommertage": 0, "heisse_Tage": 0, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 10, "kalte_Tage": 13, "Eistage": 4, "sehr_kalte_Tage": 2 }
                  16:42:47.899	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": -3.72, "Hoechstwert": 24.38, "Temp_Durchschnitt": 6.68, "Max_Windboe": 36.69, "Max_Regenmenge": 17.1, "Regenmenge_Monat": 67.8, "warme_Tage": 2, "Sommertage": 0, "heisse_Tage": 0, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 5, "kalte_Tage": 15, "Eistage": 0, "sehr_kalte_Tage": 0 }
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": -0.77, "Hoechstwert": 22.22, "Temp_Durchschnitt": 7.58, "Max_Windboe": 38.46, "Max_Regenmenge": 15.4, "Regenmenge_Monat": 43.5, "warme_Tage": 2, "Sommertage": 0, "heisse_Tage": 0, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 6, "kalte_Tage": 9, "Eistage": 0, "sehr_kalte_Tage": 0 }
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": 0.5, "Hoechstwert": 28.38, "Temp_Durchschnitt": 11.83, "Max_Windboe": 36.69, "Max_Regenmenge": 11.7, "Regenmenge_Monat": 95.7, "warme_Tage": 6, "Sommertage": 1, "heisse_Tage": 0, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 0, "kalte_Tage": 0, "Eistage": 0, "sehr_kalte_Tage": 0 }
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": 9.5, "Hoechstwert": 34.5, "Temp_Durchschnitt": 19.81, "Max_Windboe": 21.88, "Max_Regenmenge": 24.3, "Regenmenge_Monat": 72.4, "warme_Tage": 23, "Sommertage": 16, "heisse_Tage": 3, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 0, "kalte_Tage": 0, "Eistage": 0, "sehr_kalte_Tage": 0 }
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": 11.5, "Hoechstwert": 28.72, "Temp_Durchschnitt": 18.54, "Max_Windboe": 179.93, "Max_Regenmenge": 57.7, "Regenmenge_Monat": 125.1, "warme_Tage": 26, "Sommertage": 14, "heisse_Tage": 0, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 0, "kalte_Tage": 0, "Eistage": 0, "sehr_kalte_Tage": 0 }
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": 0, "Hoechstwert": 0, "Temp_Durchschnitt": 0, "Max_Windboe": 0, "Max_Regenmenge": 0, "Regenmenge_Monat": 0, "warme_Tage": 0, "Sommertage": 0, "heisse_Tage": 0, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 0, "kalte_Tage": 0, "Eistage": 0, "sehr_kalte_Tage": 0 }
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: string
                  16:42:47.900	info	javascript.0 (430) script.js.Wetter.Statistik-tabelle: { "Tiefstwert": 0, "Hoechstwert": 0, "Temp_Durchschnitt": 0, "Max_Windboe": 0, "Max_Regenmenge": 0, "Regenmenge_Monat": 0, "warme_Tage": 0, "Sommertage": 0, "heisse_Tage": 0, "Tropennaechte":0, "Wuestentage":0, "Frost_Tage": 0, "kalte_Tage": 0, "Eistage": 0, "sehr_kalte_Tage": 0 }
                  16:42:51.172	info	javascript.0 (430) Stop script script.js.Wetter.Statistik-tabelle
                  
                  

                  Kein Fehler mehr, aber ist das ok mit der Ausgabe

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

                    @nashra sagte in VIS-Tabelle für WLAN Wetterstation:

                    Kein Fehler mehr, aber ist das ok mit der Ausgabe

                    Sieht gut aus. Wenn auch deine Tabelle in der VIS funktioniert warten wir mal bis zum nächsten Monatswechsel 🙂
                    Die "console.log..." kannst du nun alle entfernen oder per "//" auskommentieren, sonst wird dein Log über kurz oder lang recht voll 😉

                    Nashra 2 Replies Last reply Reply Quote 1
                    • Nashra
                      Nashra Most Active Forum Testing @SBorg last edited by

                      @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

                      @nashra sagte in VIS-Tabelle für WLAN Wetterstation:

                      Kein Fehler mehr, aber ist das ok mit der Ausgabe

                      Sieht gut aus. Wenn auch deine Tabelle in der VIS funktioniert warten wir mal bis zum nächsten Monatswechsel 🙂
                      Die "console.log..." kannst du nun alle entfernen oder per "//" auskommentieren, sonst wird dein Log über kurz oder lang recht voll 😉

                      Ja, hatte ich schon gemacht mit //
                      Ok, dann warten wir mal bis Ende des Monats was dann passiert.
                      Vielen Dank erstmal 👍

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

                        Noch eine kleine Änderung wer denn möchte. Wenn man es jetzt in der VIS öffnet, springt er ja automatisch zum Januar 2023. Die Daten gibt es aber erst am 01. Februar. Wäre doch schön wenn er immer einen Monat weniger als den aktuellen springen würde (und für den Januar zzgl. noch -1 Jahr 🙂 ).

                        Einfach den kpl. Scheduler im Skript ersetzen:

                        schedule('*/30 * * * *', function() { 
                          //Patch -1 Monat bzw. Jahr, damit immer etwas angezeigt wird (aktuelle Monatsdaten gibt es ja hier noch keine)
                            let MonatTmp = parseInt(formatDate(getDateObject((new Date().getTime())), "MM"));
                            let JahrTmp = 0;
                            if (MonatTmp>1) { MonatTmp--; } else { MonatTmp = 12; JahrTmp = -1; }  
                          setState("javascript." + instance + ".Wetterstation.MonatAuswahl", MonatTmp) ;
                          setStateDelayed("javascript." + instance + ".Wetterstation.AuswahlJahr", parseInt(formatDate(getDateObject((new Date().getTime())), "JJJJ"))+JahrTmp ,10000);
                        });
                        
                        1 Reply Last reply Reply Quote 1
                        • Nashra
                          Nashra Most Active Forum Testing @SBorg last edited by

                          @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

                          @nashra sagte in VIS-Tabelle für WLAN Wetterstation:

                          Kein Fehler mehr, aber ist das ok mit der Ausgabe

                          Sieht gut aus. Wenn auch deine Tabelle in der VIS funktioniert warten wir mal bis zum nächsten Monatswechsel 🙂
                          Die "console.log..." kannst du nun alle entfernen oder per "//" auskommentieren, sonst wird dein Log über kurz oder lang recht voll 😉

                          Hallo @SBorg
                          es hat funktioniert, Tabelle zeigt Werte richtig an 👍 👍 👍

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

                            @nashra 😀 😎 👍 Trotzdem merkwürdig das ist...

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

                              @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

                              @nashra 😀 😎 👍 Trotzdem merkwürdig das ist...

                              jep, da hast du Recht aber ganz ehrlich, ist mir egal, hauptsache läuft jetzt 😁

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

                                @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

                                Das Design wird dir bekannt vorkommen, "deine" Version des Skriptes bei mir:

                                Hallo

                                Hast du eine aktuelle View davon?

                                Bei mir kommt in der View undefinied.

                                30f02c6c-ea06-46d5-abfd-3bc25d91525e-image.png

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

                                  @negalein
                                  Ich glaube eher du hast da ein rudimentäres Problem (ich antworte gleich im WLAN-Skript Thread).
                                  Da hat sich seit Uhrzeiten nichts dran geändert:
                                  Bild 002.png

                                  // @liv-in-sky 4.10.2021 11:45
                                  //forum: https://forum.iobroker.net/topic/38286/vis-tabelle-f%C3%BCr-wlan-wetterstation
                                  
                                  const dataInputPath="0_userdata.0.Statistik.Wetter.Data";  //SEHR WICHTIG !!!!!!!!!
                                  const inhaltFarbe="black";
                                  const inhaltHintergrund="lightgray";
                                  const monatFarbe="white";
                                  const hintergrund="gray";
                                  const htmlFarbTableBorderColor="black";
                                  const abstandZelle=6;
                                  const htmlRahmenLinien="all";
                                  const htmlSchriftgroessehtmlSchriftart=""; //nicht verwendbar!
                                  const htmlFarbFelderschrift="red";         //nicht verwendbar!
                                  const htmlSchriftgroesse="13px";
                                  const htmlSchriftart="Ubuntu-Light";       //"monospace" oder z.b. "Helvetica"
                                  const weite="auto";                        //oder "500px"
                                  
                                  let myTable="table bordercolor=\""+htmlFarbTableBorderColor+"\" border=\"2px\" cellspacing=\""+abstandZelle+"\" cellpadding=\""+abstandZelle+"\" width=\""+weite+"\" rules=\""+htmlRahmenLinien+"\" style=\"color:"+htmlFarbFelderschrift+";  font-size:"+htmlSchriftgroesse+
                                                      "; font-family:"+htmlSchriftart+";\"";
                                  
                                  const varData={ 
                                               Tiefstwert:       { einheit:"°C",   name:"Minimum Temperatur"},
                                               Hoechstwert:      { einheit:"°C",   name:"Maximum Temperatur"}, 
                                               Temp_Durchschnitt:{ einheit:"°C",   name:"Durchschnittstemperatur"},
                                               Max_Windboee:     { einheit:'km/h', name:"Max Windböe"},
                                               Max_Regenmenge:   { einheit:'l/m²', name:"Max. Regen/Tag"},
                                               Regenmenge_Monat: { einheit:'l/m²', name:"Regen"},
                                               Regentage:        { einheit:"",     name:"Regentage"},
                                               sehr_kalte_Tage:  { einheit:"",     name:"Sehr kalte Tage (Min. unter -10°C)"},
                                               Eistage:          { einheit:"",     name:"Eistage (Max. unter 0°C)"},
                                               Frost_Tage:       { einheit:"",     name:"Frosttage (Min. unter 0°C)"},
                                               kalte_Tage:       { einheit:"",     name:"Kalte Tage (Max. unter 10°C)"},
                                               warme_Tage:       { einheit:"",     name:"Warme Tage (über 20°C)"},
                                               Sommertage:       { einheit:"",     name:"Sommertage (über 25°C)"},
                                               Tropennaechte:    { einheit:"",     name:"Tropennächte (Min. über 20°C)"},
                                               heisse_Tage:      { einheit:"",     name:"Heiße Tage (über 30°C)"},
                                               Wuestentage:      { einheit:"",     name:"Wüstentage (über 35°C)"}
                                  };  
                                  const table_rowspan = Object.keys(varData).length + 1;
                                  
                                  const monate =["JANUAR","FEBRUAR","MÄRZ","APRIL","MAI","JUNI","JULI","AUGUST","SEPTEMBER","OKTOBER","NOVEMBER","DEZEMBER"];
                                  
                                  //--------------------------nix mehr ändern ab hier--------------------------------------
                                  let myObj;
                                  let myArrAll=[]
                                  let myArrErstellt=[]
                                  let tableContent;
                                  let monWahlVIS;
                                  let lastThree;
                                  
                                  //----------------------------------------------------------------------------------------
                                  function dataStuff(){
                                  let myArrAll=[]
                                  let mySelector=dataInputPath+'.*.*'
                                  $(mySelector).each(function(id) {
                                  let ida=id.split("."); let lang=ida.length; let jahri=lang-2; let moni=lang-1;
                                  let obj2 = { jahr: ida[jahri]};
                                  let obj3 = { monat: ida[moni]};
                                  let formathelp=getState(id).val;
                                  let helper;
                                  
                                  if (typeof(formathelp)=="object") {helper=getState(id).val[0];} 
                                   else if (typeof(formathelp)=="string") { helper=String(getState(id).val);
                                                                            if (helper.indexOf("[")>=0) { helper=JSON.parse(helper.substring(1, helper.length-1)); }
                                                                              else { helper=JSON.parse(helper); }  
                                                                            }
                                   else { helper=JSON.parse(getState(id).val); }
                                  
                                  helper={ ...helper, ...obj2, ...obj3}
                                  myArrAll.push(JSON.stringify(helper))
                                  });
                                  
                                  //log(myArrAll)
                                  tableContent = ""  
                                  myObj=JSON.parse("["+myArrAll.toString()+"]")
                                  if (lastThree==0) {
                                  
                                  //KOPFZEILE
                                  let choseMonth=monate[monWahlVIS-1]
                                  let choseMonthArr=choseMonth.split('')
                                  let test=""
                                  for (let i=0;i<choseMonthArr.length;i++){
                                  
                                  // log(choseMonthArr[i])
                                   test=test+choseMonthArr[i]+`
                                   `    
                                  }
                                  
                                  //log(test)
                                  //tableContent+='<td  class=\"test-klein\"  rowspan=\"17\"\">'+choseMonth+'</td><td>Wetterwerte</td>'
                                  tableContent+='<td class=\"myWetterStation\" width=\"25px\"  style=\"color:'+monatFarbe+';font-size:26px; background-color:'+hintergrund+' ; vertical-align:middle; text-align:center \"   rowspan='+table_rowspan+'\">'+test+'</td><td style=\"color:'+monatFarbe+'; background-color:'+hintergrund+'"\>Jahreswerte</td>'
                                  
                                  for (let i=0;i<myObj.length;i++) {
                                   if(parseInt(myObj[i].monat)==monWahlVIS){
                                  tableContent += '<td style=\"color:'+monatFarbe+'; background-color:'+hintergrund+'"\ align=center>'  + myObj[i].jahr+'</td>'}
                                  }; tableContent="<tr style=\"font-weight\:bold\">"+tableContent+"</tr>"
                                  
                                  //RESTZEILEN
                                  for(var index in varData){
                                   tableContent+='<td style=\"color:'+inhaltFarbe+'; background-color:'+inhaltHintergrund+'\">'+varData[index].name+'</td>'
                                   for (let i=0;i<myObj.length;i++) {
                                      if(myObj[i].monat==monWahlVIS){
                                        tableContent += '<td style=\"color:'+inhaltFarbe+'; background-color:'+inhaltHintergrund+'\" align=right>' + myObj[i][index] + ' '+ varData[index].einheit+'</td>'}
                                                                    }; tableContent="<tr>"+tableContent+"</tr>"
                                  }
                                  } //lastThree
                                  else {
                                  //log(myObj[0].monat)
                                    myObj.sort(function (alpha, beta) {
                                             if (parseInt(alpha.monat) > parseInt(beta.monat))
                                                 return 1;
                                              if (parseInt(beta.monat) > parseInt(alpha.monat))
                                                 return -1;
                                              return 0;});
                                          //    log(myObj[0].monat)
                                  //KOPFZEILE LASTTHREE
                                  let choseJahr=lastThree.toString()//formatDate(getDateObject((new Date().getTime())), "JJJJ")//monate[monWahlVIS-1]
                                  let choseMonthArr=choseJahr.split('')
                                  let test=""
                                  for (let i=0;i<choseMonthArr.length;i++){
                                  // log(choseMonthArr[i])
                                   test=test+choseMonthArr[i]+`
                                   `    
                                  }
                                  
                                  //log(test)
                                  //tableContent+='<td  class=\"test-klein\"  rowspan=\"17\"\">'+choseMonth+'</td><td>Wetterwerte</td>'
                                  tableContent+='<td class=\"myWetterStation\" width=\"25px\"  style=\"color:'+monatFarbe+';font-size:26px; background-color:'+hintergrund+' ; vertical-align:middle; text-align:center \"   rowspan='+table_rowspan+'\">'+test+'</td><td style=\"color:'+monatFarbe+'; background-color:'+hintergrund+'"\>Wetterwerte</td>'
                                  
                                  for (let i=0;i<myObj.length;i++) {
                                   if( parseInt(myObj[i].jahr)==parseInt(choseJahr) ){ //&& (parseInt(myObj[i].monat)==parseInt(monWahlVIS) || parseInt(myObj[i].monat)==parseInt(monWahlVIS)-1 || parseInt(myObj[i].monat)==parseInt(monWahlVIS)-2)){
                                  tableContent += '<td style=\"color:'+monatFarbe+'; background-color:'+hintergrund+'"\ align=center>'  + monate[parseInt(myObj[i].monat)-1]+'</td>';}
                                  }; tableContent="<tr style=\"font-weight\:bold\">"+tableContent+"</tr>"
                                  
                                  //RESTZEILEN
                                  for(var index in varData){
                                   tableContent+='<td style=\"color:'+inhaltFarbe+'; background-color:'+inhaltHintergrund+'\">'+varData[index].name+'</td>'
                                   for (let i=0;i<myObj.length;i++) {
                                    if( parseInt(myObj[i].jahr)==parseInt(choseJahr) ){ //&& (parseInt(myObj[i].monat)==parseInt(monWahlVIS) || parseInt(myObj[i].monat)==parseInt(monWahlVIS)-1 || parseInt(myObj[i].monat)==parseInt(monWahlVIS)-2)){
                                        tableContent += '<td style=\"color:'+inhaltFarbe+'; background-color:'+inhaltHintergrund+'\" align=right>' + myObj[i][index] + ' '+ varData[index].einheit+'</td>'}
                                                                    }; tableContent="<tr>"+tableContent+"</tr>"
                                  }
                                  }
                                  tableContent = '<'+myTable+' ><tbody>'+tableContent+'</tbody></table >'
                                  //log(tableContent)
                                  setState("0_userdata." + instance + ".Wetterstation.MonthlyDaten",tableContent)
                                  }
                                  
                                  //--------------------------------------------------------------------------------------------------
                                  async function main() {
                                   if (!(await existsStateAsync("0_userdata." + instance + ".Wetterstation.MonthlyDaten"))) {
                                       await createStateAsync("0_userdata." + instance + ".Wetterstation.MonthlyDaten", "leer", {type: "string", name: "MonthlyDaten", role: "value", read: true, write: true, } ); }
                                   if (!(await existsStateAsync("0_userdata." + instance + "..Wetterstation.MonatAuswahl"))) {
                                       await createStateAsync("0_userdata." + instance + ".Wetterstation.MonatAuswahl", 10, {type: "number", name: "MonatAuswahl", role: "value", read: true, write: true, } ); } 
                                   if (!(await existsStateAsync("0_userdata." + instance + ".Wetterstation.AuswahlJahr"))) {
                                       await createStateAsync("0_userdata." + instance + ".Wetterstation.AuswahlJahr", 0, {type: "number", name: "AuswahlJahr", role: "value", read: true, write: true, } ); } 
                                   lastThree = (await getStateAsync("0_userdata." + instance + ".Wetterstation.AuswahlJahr")).val //? lastThree=true : lastThree=false;  
                                   monWahlVIS=((await getStateAsync("0_userdata." + instance + ".Wetterstation.MonatAuswahl")).val ) 
                                   dataStuff(); 
                                  }
                                  
                                  //-----------------------------------------------------------------------------------------------------
                                  main()
                                  
                                  on({id: "0_userdata." + instance + ".Wetterstation.MonatAuswahl", change: "any"}, async function (obj) {
                                   main()
                                  });
                                  
                                  on({id: "0_userdata." + instance + ".Wetterstation.AuswahlJahr", change: "any"}, async function (obj) {
                                   main()
                                  });
                                  
                                  schedule('*/30 * * * *', function() { 
                                   //Patch -1 Monat bzw. Jahr, damit immer etwas angezeigt wird (aktuelle Monatsdaten gibt es ja hier noch keine)
                                     let MonatTmp = parseInt(formatDate(getDateObject((new Date().getTime())), "MM"));
                                     let JahrTmp = 0;
                                     if (MonatTmp>1) { MonatTmp--; } else { MonatTmp = 12; JahrTmp = -1; }  
                                   setState("0_userdata." + instance + ".Wetterstation.MonatAuswahl", MonatTmp) ;
                                   setStateDelayed("0_userdata." + instance + ".Wetterstation.AuswahlJahr", parseInt(formatDate(getDateObject((new Date().getTime())), "JJJJ"))+JahrTmp ,10000);
                                  });
                                  
                                  


                                  Springt immer zu aktuellem Monat minus 1 (also gerade heute dann automatisch auf Mai), im Januar dann auf Dezember und minus 1 Jahr.

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

                                    @sborg sagte in VIS-Tabelle für WLAN Wetterstation:

                                    Da hat sich seit Uhrzeiten nichts dran geändert:

                                    Hast du auch einen VIS-Export für mich?

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

                                      @negalein
                                      Ist wahrscheinlich gleich mit deinem

                                      [{"tpl":"tplJquiSelectList","data":{"oid":"0_userdata.0.Wetterstation.AuswahlJahr","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":true,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","values":"0;2020;2021;2022;2023;2024","texts":"All Years;2020;2021;2022;2023;2024","height":"100","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"no_style":true},"style":{"left":"160px","top":"375px","box-shadow":"8px 8px 8px rgba(20, 20, 20, 50)"},"widgetSet":"jqui"},{"tpl":"tplHtml","data":{"g_fixed":false,"g_visibility":false,"g_css_font_text":true,"g_css_background":false,"g_css_shadow_padding":true,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","refreshInterval":"0","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"html":"{0_userdata.0.Wetterstation.MonthlyDaten}"},"style":{"left":"160px","top":"405px","width":"auto","height":"auto","font-family":"","color":"#f7f51d","z-index":"1","box-shadow":"8px 8px 8px rgba(20, 20, 20, 50)"},"widgetSet":"basic"},{"tpl":"tplJquiSelectList","data":{"oid":"0_userdata.0.Wetterstation.MonatAuswahl","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":true,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","values":"1;2;3;4;5;6;7;8;9;10;11;12","texts":"JANUAR;FEBRUAR;MÄRZ;APRIL;MAI;JUNI;JULI;AUGUST;SEPTEMBER;OKTOBER;NOVEMBER;DEZEMBER","height":"100","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"no_style":true},"style":{"left":"260px","top":"375px","width":"100px","height":"","box-shadow":"8px 8px 8px rgba(20, 20, 20, 50)","z-index":"1"},"widgetSet":"jqui"}]
                                      
                                      T 1 Reply Last reply Reply Quote 1
                                      • T
                                        tritor @SBorg last edited by

                                        @sborg

                                        habe heute mal die Vis aktiviert und muß sagen, bin begeistert.

                                        1 Reply Last reply Reply Quote 0
                                        • First post
                                          Last post

                                        Support us

                                        ioBroker
                                        Community Adapters
                                        Donate

                                        481
                                        Online

                                        31.9k
                                        Users

                                        80.1k
                                        Topics

                                        1.3m
                                        Posts

                                        vis
                                        11
                                        101
                                        10240
                                        Loading More Posts
                                        • Oldest to Newest
                                        • Newest to Oldest
                                        • Most Votes
                                        Reply
                                        • Reply as topic
                                        Log in to reply
                                        Community
                                        Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                        The ioBroker Community 2014-2023
                                        logo