Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Praktische Anwendungen (Showcase)
    4. [Linux Shell-Skript] WLAN-Wetterstation

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

    [Linux Shell-Skript] WLAN-Wetterstation

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

      @sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:

      Dann unter 0_userdata.0.Statistik.Wetter.Rekordwerte.Trockenperiode noch 18 Tage im April 2021

      Danke dir!
      Hier auch "Bestätigt" an haken?

      aber mich stört die "javascript-Instanz.1"

      Hatte es nur in der Testphase unter .1 laufen. Läuft jetzt schon ewig in .0

      außer es hätte wirklich in den letzten 8 Monaten jeden Tag bei dir geregnet...

      Gott sei dank nicht! 😁

      führe wetterstation.js (oder wie du es genannt hast) wieder einmalig aus, damit er die DPs neu anlegt

      gemacht und bemerkt, dass er die DP nicht neu anlegt.
      Hab dann Lokal und auf Github kontrolliert.
      Im Script scheint "Trockenperiode, usw.) nicht auf.

      //Wetterstation Datenpunkte anlegen V2.9.0
       let DP="javascript.0.Wetterstation.";
       let DP50  = 0;  // Anzahl der DP50 Sensoren  (max. 8 Stück)
       let DP60  = 0;  // Anzahl der DP60 Sensoren  (max. 1 Stück)
       let DP70  = 0;  // Anzahl der DP70 Sensoren  (max. 4 Stück)
       let DP100 = 0;  // Anzahl der DP100 Sensoren (max. 8 Stück)
       let DP200 = 0;  // Anzahl der DP200 Sensoren (max. 4 Stück)
       let DP250 = 0;  // Anzahl der DP250 Sensoren (max. 1 Stück)
       //Ende der User-Einstellungen -------------------
      
        createState(DP+"Innentemperatur"             , 0,    {name: "Temperatur im Haus",                    type: "number", role: "state", unit: "°C" });
        createState(DP+"Aussentemperatur"            , 0,    {name: "Temperatur Außen",                      type: "number", role: "state", unit: "°C" });
        createState(DP+"Taupunkt"                    , 0,    {name: "Taupunkt",                              type: "number", role: "state", unit: "°C" });
        createState(DP+"Gefuehlte_Temperatur"        , 0,    {name: "Windchill",                             type: "number", role: "state", unit: "°C" });
        createState(DP+"Innenfeuchtigkeit"           , 0,    {name: "Luftfeuchtigkeit Innen",                type: "number", role: "state", unit: "%" });
        createState(DP+"Aussenfeuchtigkeit"          , 0,    {name: "Luftfeuchtigkeit Außen",                type: "number", role: "state", unit: "%" });
        createState(DP+"Wind"                        , 0,    {name: "Windgeschwindigkeit",                   type: "number", role: "state", unit: "km/h" });
        createState(DP+"Wind_max"                    , 0,    {name: "Windgeschwindigkeit maximal",           type: "number", role: "state", unit: "km/h" });
        createState(DP+"Windrichtung"                , 0,    {name: "Windrichtung in Grad",                  type: "number", role: "state", unit: "°" });
        createState(DP+"Windrichtung_Text"           ," ",   {name: "Windrichtung als Text",                 type: "string", role: "state" });
        createState(DP+"Druck_absolut"               , 0,    {name: "Luftdruck absolut",                     type: "number", role: "state", unit: "hPa" });
        createState(DP+"Druck_relativ"               , 0,    {name: "Luftdruck relativ",                     type: "number", role: "state", unit: "hPa" });
        createState(DP+"Druck_Tendenz"               ,"",    {name: "Luftdrucktendenz",                      type: "mixed",  role: "state" });
        createState(DP+"Wetter_Trend"                ," ",   {name: "Wettertrend",                           type: "string", role: "state" });
        createState(DP+"Wetter_aktuell"              ," ",   {name: "aktuelles Wetter",                      type: "string", role: "state" });
        createState(DP+"Regenrate"                   , 0,    {name: "Regenrate",                             type: "number", role: "state", unit: "mm/h" });
        createState(DP+"Regenstatus"                 ,"--",  {name: "aktueller Regenstatus",                 type: "string", role: "state" });
        createState(DP+"Regen_Tag"                   , 0,    {name: "Regenmenge Heute",                      type: "number", role: "state", unit: "mm" });
        createState(DP+"Regen_Woche"                 , 0,    {name: "Regenmenge Woche",                      type: "number", role: "state", unit: "mm" });
        createState(DP+"Regen_Monat"                 , 0,    {name: "Regenmenge Monat",                      type: "number", role: "state", unit: "mm" });
        createState(DP+"Regen_Jahr"                  , 0,    {name: "Regenmenge Jahr aus Station",           type: "number", role: "state", unit: "mm" });
        createState(DP+"Regen_Jahr_kumuliert"        , 0,    {name: "Regenmenge Jahr berechnet",             type: "number", role: "state", unit: "mm" });
        createState(DP+"Sonnenstrahlung"             , 0,    {name: "Sonnenstrahlung",                       type: "number", role: "state", unit: "W/m²" });
        createState(DP+"UV_Index"                    , 0,    {name: "UV Index",                              type: "number", role: "state" });
        createState(DP+"UV_Belastung"                ," ",   {name: "UV-Belastung",                          type: "string", role: "state" });
        createState(DP+"Zeitstempel"                 ," ",   {name: "von wann ist die Messung",              type: "string", role: "state" });
        createState(DP+"_Kommunikationsfehler"       , false,{name: "liegt ein Problem vor",                 type: "boolean",role: "state" });
        createState(DP+"tempData.Wetterdaten"        ," ",   {name: "temporär gespeicherte Wetterdaten",     type: "string" ,role: "state" });
        createState(DP+"tempData.Sonnenschein"       ," ",   {name: "temporäre Daten Tag, Woche, Monat, Jahr",type: "string",role: "state" });
        createState(DP+"tempData.Solarenergie"       ,"0",   {name: "temporäre Daten Tag, Woche, Monat, Jahr",type: "string",role: "state" });
        createState(DP+"Info.FW_Upgrade"             , false,{name: "neue Firmware für die Station",         type: "boolean",role: "state" });
        createState(DP+"Info.FW_Version"             ," ",   {name: "Firmwareversion der Station",           type: "string", role: "state" });
        createState(DP+"Info.Hitzeindex"             , 0,    {name: "Hitzeindex (erst ab 20°C)",             type: "mixed", role: "state", unit: "°C" });
        createState(DP+"Info.openSenseMap"           , false,{name: "Datenübertragung openSenseMap erfolgreich",type: "boolean",role: "state" });
        createState(DP+"Info.Windy"                  , false,{name: "Datenübertragung Windy erfolgreich",    type: "boolean",role: "state" });
        createState(DP+"Info.Wetter_com"             , false,{name: "Datenübertragung Wetter.com erfolgreich",type: "boolean",role: "state" });
        createState(DP+"Info.Sonnenschein_VorTag"    , 0,    {name: "Sonnenscheindauer Gestern",             type: "number", role: "state", unit: "Sek." });
        createState(DP+"Info.Sonnenschein_Tag"       , 0,    {name: "Sonnenscheindauer Heute",               type: "number", role: "state", unit: "Sek." });
        createState(DP+"Info.Sonnenschein_Woche"     , 0,    {name: "Sonnenscheindauer diese Woche",         type: "number", role: "state", unit: "Sek." });
        createState(DP+"Info.Sonnenschein_Monat"     , 0,    {name: "Sonnenscheindauer diesen Monat",        type: "number", role: "state", unit: "Sek." });
        createState(DP+"Info.Sonnenschein_Jahr"      , 0,    {name: "Sonnenscheindauer dieses Jahr",         type: "number", role: "state", unit: "Sek." });
        createState(DP+"Info.Sonnenschein_Tag_Text"  ," ",   {name: "Sonnenscheindauer Heute als Text",      type: "string", role: "state" });
        createState(DP+"Info.Sonnenschein_Woche_Text"," ",   {name: "Sonnenscheindauer diese Woche als Text",type: "string", role: "state" });
        createState(DP+"Info.Sonnenschein_Monat_Text"," ",   {name: "Sonnenscheindauer diesen Monat als Text",type: "string", role: "state" });
        createState(DP+"Info.Sonnenschein_Jahr_Text" ," ",   {name: "Sonnenscheindauer dieses Jahr als Text",type: "string", role: "state" });
        createState(DP+"Info.Sonnenschein_VorJahr"   , 0,    {name: "Sonnenscheindauer letztes Jahr",        type: "number", role: "state", unit: "Sek." });
        createState(DP+"Info.Regenmenge_VorJahr"     , 0,    {name: "Regenmenge letztes Jahr",               type: "number", role: "state", unit: "mm" });
        createState(DP+"Info.Solarenergie_VorTag"    , 0,    {name: "Solarenergie Gestern",                  type: "number", role: "state", unit: "Wh/m²" });
        createState(DP+"Info.Solarenergie_Tag"       , 0,    {name: "Solarenergie Heute",                    type: "number", role: "state", unit: "Wh/m²" });
        createState(DP+"Info.Solarenergie_Woche"     , 0,    {name: "Solarenergie diese Woche",              type: "number", role: "state", unit: "kWh/m²" });
        createState(DP+"Info.Solarenergie_Monat"     , 0,    {name: "Solarenergie diesen Monat",             type: "number", role: "state", unit: "kWh/m²" });
        createState(DP+"Info.Solarenergie_Jahr"      , 0,    {name: "Solarenergie dieses Jahr",              type: "number", role: "state", unit: "kWh/m²" });
        createState(DP+"Info.Solarenergie_VorJahr"   , 0,    {name: "Solarenergie letztes Jahr",             type: "number", role: "state", unit: "kWh/m²" });
        createState(DP+"Info.Letzter_Regen"          ," ",   {name: "letztes Regenereignis",                 type: "string", role: "state" });
        createState(DP+"Info.Letzte_Regenmenge"      , 0,    {name: "letzte Regenmenge",                     type: "number", role: "state", unit: "mm" });
        createState(DP+"Info.Station_Batteriestatus" , 0,    {name: "Batteriestatus [0=OK, 1=Alarm]",        type: "number", role: "state" });
        createState(DP+"Info.Wetterstation_Gateway"  , 0,    {name: "Gateway Informationen",                 type: "string", role: "state" });
        createState(DP+"Info.Temp_Aussen_Heute_max"  , 0,    {name: "bisher höchste Aussentemperatur des heutigen Tages",type: "number", role: "value", unit: "°C" });
        createState(DP+"Info.Temp_Aussen_Heute_min"  , 0,    {name: "bisher niedrigste Aussentemperatur des heutigen Tages",type: "number", role: "value", unit: "°C" });
        createState(DP+"Info.Temp_Aussen_24h_max"    , 0,    {name: "höchste Aussentemperatur der letzten 24 Stunden",type: "number", role: "state", unit: "°C" });
        createState(DP+"Info.Temp_Aussen_24h_min"    , 0,    {name: "tiefste Aussentemperatur der letzten 24 Stunden",type: "number", role: "state", unit: "°C" });
        createState(DP+"Info.Temp_Aussen_365t_min"   , 0,    {name: "tiefste Aussentemperatur vor einem Jahr",type: "number", role: "state", unit: "°C" });
        createState(DP+"Info.Temp_Aussen_365t_max"   , 0,    {name: "höchste Aussentemperatur vor einem Jahr",type: "number", role: "state", unit: "°C" });
        createState(DP+"Info.Temp_Aussen_365t_avg"   , 0,    {name: "durchschnittliche Aussentemperatur vor einem Jahr",type: "number", role: "state", unit: "°C" });
        createState(DP+"Windboeen_max"               , 0,    {name: "Windböengeschwindigkeit maximal",       type: "number", role: "state", unit: "km/h" });
        createState(DP+"Regen_Event"                 , 0,    {name: "Regenmenge Event",                      type: "number", role: "state", unit: "mm" });
        createState(DP+"Regen_Stunde"                , 0,    {name: "Regenmenge Stunde",                     type: "number", role: "state", unit: "mm" });
        createState(DP+"Regen_Total"                 , 0,    {name: "Regenmenge Insgesammt",                 type: "number", role: "state", unit: "mm" });
      
      
      
      if (DP50>0 && DP50<=8)  {
        if (!existsState(DP + "DP50")) {createState(DP + "DP50", '', { name: "Mehrkanal Thermo-Hygrometersensoren" });}
        for(var i=1; i<=DP50; i++) {
          if (!existsState(DP + "DP50." + i + ".Temperatur")) {
              createState(DP + "DP50." + i + ".Temperatur", "", {
                  "name": "DP50 Kanal " + i + " Temperatur",
                  "type": "number",
                  "role": "state",
                  "unit": "°C"
              });
          }
          if (!existsState(DP + "DP50." + i + ".Feuchtigkeit")) {
              createState(DP + "DP50." + i + ".Feuchtigkeit", "", {
                  "name": "DP50 Kanal " + i + " Feuchtigkeit",
                  "type": "number",
                  "role": "state",
                  "unit": "%"
              });
          }
          if (!existsState(DP + "DP50." + i + ".Batterie")) {
              createState(DP + "DP50." + i + ".Batterie", "", {
                  "name": "DP50 Kanal " + i + " Batterie",
                  "type": "number",
                  "role": "state",
              });
          }
        }
      }
      
      if (DP60>0 && DP60<=1)  {
        if (!existsState(DP + "DP60")) {createState(DP + "DP60", '', { name: "Blitzdetektor" });}
        for(let i=1; i<=DP60; i++) {
          if (!existsState(DP + "DP60." + i + ".Entfernung")) {
              createState(DP + "DP60." + i + ".Entfernung", "", {
                  "name": "DP60 Kanal " + i + " Entfernung",
                  "type": "number",
                  "role": "state",
                  "unit": "km"
              });
          }
          if (!existsState(DP + "DP60." + i + ".Zeitpunkt")) {
              createState(DP + "DP60." + i + ".Zeitpunkt", "", {
                  "name": "DP60 Kanal " + i + " Zeitpunkt (Unix-Timestamp)",
                  "type": "number",
                  "role": "state"
              });
          }
          if (!existsState(DP + "DP60." + i + ".Anzahl")) {
              createState(DP + "DP60." + i + ".Anzahl", "", {
                  "name": "DP60 Kanal " + i + " Anzahl innerhalb von 24 Stunden",
                  "type": "number",
                  "role": "state"
              });
          }
          if (!existsState(DP + "DP60." + i + ".Batterie")) {
              createState(DP + "DP60." + i + ".Batterie", "", {
                  "name": "DP60 Kanal " + i + " Batterie (5 = max)",
                  "type": "number",
                  "role": "state",
              });
          }
        }
      }
      
      if (DP70>0 && DP70<=4) {
        if (!existsState(DP + "DP70")) {createState(DP + "DP70", '', { name: "Mehrkanal-Wasserlecksensoren" });}
        for(var i=1; i<=DP70; i++) {
          if (!existsState(DP + "DP70." + i + ".Status")) {
              createState(DP + "DP70." + i + ".Status", "", {
                  "name": "DP70 Kanal " + i + " Status (normal/Alarm)",
                  "type": "string",
                  "role": "state"
              });
          }
          if (!existsState(DP + "DP70." + i + ".Batterie")) {
              createState(DP + "DP70." + i + ".Batterie", "", {
                  "name": "DP70 Kanal " + i + " Batterie",
                  "type": "number",
                  "role": "state",
              });
          }
        }
      }
      
      if (DP100>0 && DP100<=8) {
        if (!existsState(DP + "DP100")) {createState(DP + "DP100", '', { name: "Mehrkanal Bodenfeuchtesensoren" });}
        for(var i=1; i<=DP100; i++) {
          if (!existsState(DP + "DP100." + i + ".Bodenfeuchtigkeit")) {
              createState(DP + "DP100." + i + ".Bodenfeuchtigkeit", "", {
                  "name": "DP100 Kanal " + i + " Bodenfeuchtigkeit",
                  "type": "number",
                  "role": "state",
                  "unit": "%"
              });
          }
          if (!existsState(DP + "DP100." + i + ".Batterie")) {
              createState(DP + "DP100." + i + ".Batterie", "", {
                  "name": "DP100 Kanal " + i + " Batterie",
                  "type": "number",
                  "role": "state",
              });
          }
        }
      }
      
      if (DP200>0 && DP200<=4) {
        if (!existsState(DP + "DP200")) {createState(DP + "DP200", '', { name: "Feinstaub Emissionssensoren" });}
        for(var i=1; i<=DP200; i++) {
          if (!existsState(DP + "DP200." + i + ".PM25")) {
              createState(DP + "DP200." + i + ".PM25", "", {
                  "name": "DP200 Kanal " + i + " 2.5µm Partikel",
                  "type": "number",
                  "role": "state",
                  "unit": "µg/m³"
              });
          }
          if (!existsState(DP + "DP200." + i + ".PM25_24h")) {
              createState(DP + "DP200." + i + ".PM25_24h", "", {
                  "name": "DP200 Kanal " + i + " Durchschnitt per 24h",
                  "type": "number",
                  "role": "state",
                  "unit": "µg/m³"
              });
          }
          if (!existsState(DP + "DP200." + i + ".Batterie")) {
              createState(DP + "DP200." + i + ".Batterie", "", {
                  "name": "DP200 Kanal " + i + " Batterie (5 = max)",
                  "type": "number",
                  "role": "state",
              });
          }
        }
      }
      
      if (DP250>0 && DP250<=1)  {
        if (!existsState(DP + "DP250")) {createState(DP + "DP250", '', { name: "5-In-1 CO2 / PM2.5 / PM10 / Temperatur / Luftfeuchte Innenraumsensor" });}
        for(let i=1; i<=DP250; i++) {
          if (!existsState(DP + "DP250." + i + ".Temperatur")) {
              createState(DP + "DP250." + i + ".Temperatur", "", {
                  "name": "DP250 Kanal " + i + " Temperatur",
                  "type": "number",
                  "role": "value",
                  "unit": "°C"
              });
          }
          if (!existsState(DP + "DP250." + i + ".Luftfeuchtigkeit")) {
              createState(DP + "DP250." + i + ".Luftfeuchtigkeit", "", {
                  "name": "DP250 Kanal " + i + " Luftfeuchtigkeit",
                  "type": "number",
                  "role": "value",
                  "unit": "%"
              });
          }
          if (!existsState(DP + "DP250." + i + ".PM25")) {
              createState(DP + "DP250." + i + ".PM25", "", {
                  "name": "DP250 Kanal " + i + " 2.5µm Partikel",
                  "type": "number",
                  "role": "value",
                  "unit": "µg/m³"
              });
          }
          if (!existsState(DP + "DP250." + i + ".PM25_24h")) {
              createState(DP + "DP250." + i + ".PM25_24h", "", {
                  "name": "DP250 Kanal " + i + " Durchschnitt per 24h",
                  "type": "number",
                  "role": "value",
                  "unit": "µg/m³"
              });
          }
          if (!existsState(DP + "DP250." + i + ".PM10")) {
              createState(DP + "DP250." + i + ".PM10", "", {
                  "name": "DP250 Kanal " + i + " 10µm Partikel",
                  "type": "number",
                  "role": "value",
                  "unit": "µg/m³"
              });
          }
          if (!existsState(DP + "DP250." + i + ".PM10_24h")) {
              createState(DP + "DP250." + i + ".PM10_24h", "", {
                  "name": "DP250 Kanal " + i + " Durchschnitt per 24h",
                  "type": "number",
                  "role": "value",
                  "unit": "µg/m³"
              });
          }
          if (!existsState(DP + "DP250." + i + ".CO2")) {
              createState(DP + "DP250." + i + ".CO2", "", {
                  "name": "DP250 Kanal " + i + " CO2-Konzentration",
                  "type": "number",
                  "role": "value",
                  "unit": "ppm"
              });
          }
          if (!existsState(DP + "DP250." + i + ".CO2_24h")) {
              createState(DP + "DP250." + i + ".CO2_24h", "", {
                  "name": "DP250 Kanal " + i + " Durchschnitt per 24h",
                  "type": "number",
                  "role": "value",
                  "unit": "ppm"
              });
          }
          if (!existsState(DP + "DP250." + i + ".Batterie")) {
              createState(DP + "DP250." + i + ".Batterie", "", {
                  "name": "DP250 Kanal " + i + " Batterie (6 = max)",
                  "type": "number",
                  "role": "value",
              });
          }
        }
      }
      

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

        @sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:

        Meteorologischer Sommer ist vom 1.6. - 31.8. wenn ich mich nicht irre?

        genau

        ... und bevor ich es dann falsch mache (ohne deinem Cousin zu Nahe treten zu wollen): fehlt da nicht ein "o", hat ja nix mit einem "Meteor" zu tun?

        😂 😂 😂

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

          @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

          Hier auch "Bestätigt" an haken?

          Da es ein reiner "Anzeige-DP" ist, ist es da egal. Mich stört halt immer nur die Einfärbung bei "unbestätigt", dass hat so irgendwie etwas von einem Fehlercharakter 😉

          @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

          Hab dann Lokal und auf Github kontrolliert.

          Kann ja auch nicht, schei*e wenn man blöd ist...
          Das ist doch nicht Shell-Skript, sondern Statistik...🙃
          Sorry, einfach das Statistik-Skript stoppen, da sind die DPs mit drin. Dann ~#69 editieren:

          const DP_Check='Rekordwerte.Regenmengemonat';
          

          in

          const DP_Check='Rekordwerte.Trockenperiode';
          

          Dann werden alle fehlenden DPs nach Start des Skriptes wieder angelegt 🙂

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

            @sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:

            Sorry, einfach das Statistik-Skript stoppen, da sind die DPs mit drin. Dann ~#69 editieren:

            erledigt

            Dann hat er deswegen die Periode nicht berechnet?

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

              @negalein Nein, die Änderung ist nur weil er sonst die Datenpunkte nicht mehr anlegt.
              Ich vermute einen Fehler bzgl. des/der Datenpunkte/s wie bspw. "Read Only" oä.

              Met. Sommer-Temp 😊
              Bild 1.png

              Regen ist aber K*cke, da er hier die Werte fort schreibt. Da muss ich mir in einer ruhigen Minute (=also nie 😂 ) erst mal wieder Gedanken machen.
              Die Berechnungen/Datenbankabfrage macht eigentlich auch nur Sinn vom 01.06. - ~September
              Die restlichen 9 Monate wäre sie ja unnütz, aber wie käme man aktuell an die Daten für den Met.-Sommer 2021? Einfach immer laufen lassen ist mehr als kontraproduktiv, da die Regenmenge wohl wieder in einem "Datenbankabfragedesaster" endet. Soll heißen, auf einem PI kann das wieder 1-2 Minuten dauern...


              btw: so sieht die neue Version des Statistik-Skriptes derzeit aus. Alles wg. des JSC 3.x ... 😉
              Bild 2.png

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

                @sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                Ich vermute einen Fehler bzgl. des/der Datenpunkte/s wie bspw. "Read Only" oä.

                Quasi dieses ACK-Ding? Oder kann ich das selbst überprüfen?

                in einer ruhigen Minute (=also nie )

                Ich schick dir ein Ommmm 😁

                Die Berechnungen/Datenbankabfrage macht eigentlich auch nur Sinn vom 01.06. - ~September

                Ja, eigentlich nur bis 31. 8.! Also am 1. 9. um 1:03 müsste er es berechnen.

                Die restlichen 9 Monate wäre sie ja unnütz, aber wie käme man aktuell an die Daten für den Met.-Sommer 2021? Einfach immer laufen lassen ist mehr als kontraproduktiv, da die Regenmenge wohl wieder in einem "Datenbankabfragedesaster" endet. Soll heißen, auf einem PI kann das wieder 1-2 Minuten dauern...

                Eventuell vorerst für 2021 als Option (true/false).
                Wer will solls machen, wer eine schwache Maschine hat, kann dann eh entscheiden ob ers macht.

                btw: so sieht die neue Version des Statistik-Skriptes derzeit aus. Alles wg. des JSC 3.x ... 😉

                Also so wie oben gemeint mit dem ACK-Ding?

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

                  @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                  Quasi dieses ACK-Ding? Oder kann ich das selbst überprüfen?

                  Jein. Ack ist nur für die "Weiterverarbeitung" ggf. nötig. Damit wird der Wert "bestätigt", quasi ein "schalte xyz ein" und der meldet dann zurück "eingeschaltet". Ich setze den Ack=true wo es möglich ist (bei Bulk-Updates per Simple-API-Adapter geht es bspw. nicht) nur weil die Einfärbung der DPs wie ein Fehler aussieht. Das verursacht bei dem ein oder anderen User dann schon Schnappatmung 😉
                  Nachschauen kann man dann beim DP in den Objektdaten ob dort read/write auf true/false steht. Bei keinem Eintrag ist es automatisch true, also erlaubt

                  @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                  Ich schick dir ein Ommmm

                  😂

                  @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                  Ja, eigentlich nur bis 31. 8.! Also am 1. 9. um 1:03 müsste er es berechnen.

                  01:03 Uhr wäre Statistik, das macht aber das Shell-Skript. Deswegen kann ich es einfach für die Monate 6,7 und 8 ausführen lassen, da die Mitternachtjobs gegen 23:58 Uhr laufen. Somit läuft es letztmalig am 31.08. gegen 23:58 Uhr. Man möge die dann ggf. fehlenden 1-2 Messwerte verzeihen 😁
                  Da ich die Regenabfrage relativ komfortabel lösen konnte was die Verarbeitungszeit angeht, wird es bei aktiver InfluxDB automatisch aktiv. Muss es "nur" noch implementieren. Die Ausführung für dieses Jahr (wir haben ja bereits September, da läuft die Auswertung nicht mehr 😉 ) geht dann manuell per Parameter, sogar bei aktivem/laufendem Service:
                  Bild 1.png

                  @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                  Also so wie oben gemeint mit dem ACK-Ding?

                  Nö, mit dem JSC 3.x muss ein JSON-String ein Array sein (aktuell passiert zwar noch nix, kann sich aber mit einer neuen Version jederzeit ändern). Das habe ich zwar geändert, dabei aber vergessen, dass ich es dann im Umkehrschluss auch als Array wieder einlesen muss. Als letzte Werte steht halt im JSON-String dann zufällig "ack: true", was er dann als Datenpunktwert nutzt...

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

                    @sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                    geht dann manuell per Parameter, sogar bei aktivem/laufendem Service:

                    Cool, freu mich! 🙂

                    da_Woody 1 Reply Last reply Reply Quote 0
                    • da_Woody
                      da_Woody @Negalein last edited by

                      @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                      Coll

                      ahja? 😄

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

                        Flasche all, habe fertig 😂

                        Bereit zum testen:
                        Bild 1.png

                        • sh + sub ersetzen
                        • js ebenfalls + einmalig ausführen wg. neuer DPs (.Info.Regenmenge_Met_Sommer + .Info.Temp_Met_Sommer_avg)
                        • zur Berechnung im Verzeichnis ./wetterstation.sh --metsommer ausführen

                        Changelog:

                        + Min-/Max-Aussentemperatur des heutigen Tages
                        ~ Änderung bei Datenübertragung per Simple-API wg. InfluxDB 2.x
                        + Meteorologischer Sommer Durchschnittstemperatur und Regenmenge
                        + neuer Shell-Parameter --metsommer (zur manuellen Berechnung der Werte des meteorologischen Sommers)
                        

                        Die meteoroligischen Sommerwerte werden bei aktivierter InfluxDB automatisch vom 01.06. bis zum 31.08. des Jahres ermittelt. Per Option "--metsommer" (Service muss dazu nicht deaktiviert werden!) lassen sich die Werte auch nachträglich für das laufende Jahr ermitteln, solange Daten für den Zeitraum vorliegen.
                        Die Ausführung in der Zeit vom 01.01. bis 31.05. wird mangels Daten nicht ausgeführt.

                        Wie immer im GitHub...

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

                          😁

                          metosommer.PNG

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

                            @sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                            zur Berechnung im Verzeichnis ./wetterstation.sh --metsommer ausführen

                            Super 🙂

                            /home/iobroker/wetterstation.conf: Zeile 136: am: Kommando nicht gefunden.
                            
                             Daten vom 01.06.2021 bis 31.08.2021 wurden ermittelt...
                            
                                     Ø-Temperatur: 20.04 °C
                                     Regenmenge  : 343.9 l/m²
                            
                            dietpi@DietPi:/home/iobroker$
                            

                            was bedeutet, /home/iobroker/wetterstation.conf: Zeile 136: am: Kommando nicht gefunden.?

                            Boronsbruder 1 Reply Last reply Reply Quote 0
                            • Boronsbruder
                              Boronsbruder @Negalein last edited by Boronsbruder

                              @negalein
                              Dass er das Kommando in Zeile 136 nicht gefunden hat
                              (sorry der musste sein) 🤣

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

                                @boronsbruder sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                                Das er das Kommando in Zeile 136 nicht gefunden hat
                                (sorry der musste sein)

                                👅
                                Ja, mit dem hätt ich rechnen müssen! 😉

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

                                  @negalein Das muss aber schon länger sein, ist jetzt nur durch das händische starten aufgefallen.

                                  wetterstation.conf mittels nano öffnen, dann STRG+[Unterstrich/Gedankenstrich] drücken, 138 eingeben und [ENTER] drücken.
                                  Wie sieht die Zeile aus? Du musst da ein "am:" drin stehen haben, was da nix zu suchen hat 😉
                                  #138 ist im Original eine Leerzeile

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

                                    @sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                                    Das muss aber schon länger sein, ist jetzt nur durch das händische starten aufgefallen.

                                    gefunden

                                    Nach WETTERCOM_PW= waren bei mir nur 3 Leerzeilen.
                                    Im Original aber 4.

                                    Das am ist von Wernstein am Inn gekommen.

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

                                      @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                                      Nach WETTERCOM_PW= waren bei mir nur 3 Leerzeilen.
                                      Im Original aber 4.

                                      Das kann es aber nicht gewesen sein. Die Leerzeilen sind nur für die Übersichtlichkeit und die Abstände werden nicht ausgewertet (so ala "lies Zeile xyz"). Nur die Kopfzeile der Datei muss so bleiben wie sie ist, da hier die Versionsinformation der Datei ermittelt wird. Ansonsten sind die Einrückungen und Gruppierungen nur rein Optik.

                                      Ev. hattest du auch ein unsichtbares CR drin, dass mag Linux überhaupt nicht 😉

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

                                        @sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                                        Ev. hattest du auch ein unsichtbares CR drin, dass mag Linux überhaupt nicht

                                        Nein, nichts dergleichen.

                                        Jetzt (nach dem löschen (hab mich vorhin verschrieben) der Leerzeile) nennt er #137.
                                        Das war vorher #138.
                                        In #137 steht windy_Name=Wernstein am Inn -- Oehret.
                                        Ich denke er kommt hier mit den Leerzeichen nicht klar.

                                        /home/iobroker/wetterstation.conf: Zeile 137: am: Kommando nicht gefunden.
                                        
                                         Daten vom 01.06.2021 bis 31.08.2021 wurden ermittelt...
                                        
                                                 Ø-Temperatur: 20.04 °C
                                                 Regenmenge  : 343.9 l/m²
                                        
                                        SBorg 1 Reply Last reply Reply Quote 0
                                        • SBorg
                                          SBorg Forum Testing Most Active @Negalein last edited by SBorg

                                          @negalein sagte in [Linux Shell-Skript] WLAN-Wetterstation:

                                          Ich denke er kommt hier mit den Leerzeichen nicht klar.

                                          Jepp, deswegen mäkelt er auch "am" an.
                                          windy_Name="Wernstein am Inn -- Oehret" sollte aber funktionieren.


                                          Wenn ich mir so eure Werte anschaue, war es bei euch aber eher kühl und nass 😉
                                          Kontrolliert dann bitte mal die LCs/TS' der beiden neuen DPs. Die sollten sich nun nicht mehr ändern (bis zum 01.06.2022), außer ihr führt nochmals "--metsommer" aus (wird aber keine anderen Daten mehr liefern 😁 ).

                                          btw: Macht es Sinn die beiden DPs zum 01.01. zu löschen, oder dann einfach am 01.06. überschreiben zu lassen (wäre aktuell so)?

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

                                            Moin, ich würde sagen zum 01.01. löschen bzw. auf 0 setzen.
                                            Aber die Mehrheit entscheidet 🙂

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            896
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            linux shell-script wetterstation wlan-wetterstation
                                            141
                                            5399
                                            2874134
                                            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