NEWS
[Linux Shell-Skript] WLAN-Wetterstation
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Dann würde das FW-Upgrade noch funktionieren (ist ja auf dem Display) und die Station würde aus der App fliegen...
Ja, die Daten am Display sind plausiebel und für mein Dafürhalten aktuell.
Ja, nach dem Stromausfall waren neben der Wetterstation in der App auch sämtliche Einstellungen am Display weg (Uhrzeit, Datum, ...)
Nachdem ich die Station wieder mit der App verband kamen diese Daten aber wieder am Display vollkommen richtig an (Uhrzeit, Datum, ...).
Mittlerweile habe ich dein Script auf 3.0 upgedated. Leider keine Daten im iO bis jetzt.
-
@metaxa sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Mittlerweile habe ich dein Script auf 3.0 upgedated
Daran kann es leider auch nicht liegen, du könntest auch noch mit der ersten Version Daten empfangen
Uhrzeit sollte beim Display aber erhalten bleiben, dafür ist ja die Backup-Batterie im Display. Nutzt du DHCP? Nicht das die Station nun eine andere IP hat bzw. kannst du sie anpingen?
Wenn der Rechner mit dem WLAN-Skript drauf das Display erreichen kann und dies auch Daten schickt, muss mit "--data" etwas kommen (auch wenn er bei "--debug" einen Kommunikationsfehler meldet). -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
dafür ist ja die Backup-Batterie im Display
Hatte bei den bisherigen Stromunterbrechungen auch nie ein Problem damit, diesmal war alles weg bis ich die W830 in der App wieder eingebunden hatte.
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Nutzt du DHCP? Nicht das die Station nun eine andere IP hat bzw. kannst du sie anpingen?
Ja, ich nutze DHCP aber mit Zuweisungen des Routers, die IP ist gleich geblieben
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Wenn der Rechner mit dem WLAN-Skript drauf das Display erreichen kann und dies auch Daten schickt,
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Nicht das die Station nun eine andere IP hat
Nur um das auch sicherzustellen, wo kann ich ersehen welche IP Adresse von deinem Script erwartet wird? In der wetterstation.conf steht sie nicht, nur die vom iO.
Wie kann ich überprüfen ob das Display Daten schickt?
Welche Möglichkeiten habe ich noch um den Fehler zu finden und zu korrigieren?
Lieben Dank für deine Hilfe!
-
@sborg Erledigt!
Ich habe in der App auf "Protocol Type Same As: Ecowitt" umgestellt da in der config auch
#Protokoll der Wetterstation [1/2/9] / 1=Wunderground ; 2=Ecowitt ; 9=DNS / default: 2 WS_PROTOKOLL=2
stand. Plötzlich waren Daten da "freu"
LG, mxa
-
@metaxa Das sind meist allgemeinere Fragen da ich nie weiß was ihr tatsächlich wie nutzt, oder wie ist der Kenntnisstand des Nutzers etc. pp.
Tatsächlich ist es aber so, dass die IP-Adresse der Wetterstation nirgends steht. Die sendet nur das Datenpaket (und dort ist dann auch die IP oder URL und Port hinterlegt wohin). Der Rechner mit dem WLAN-Skript "hört" dann einfach nur zu ob an Port xxxxx wer anklopft und was senden möchte. Dann verarbeitet er das und schickt es seinerseits wieder an die in der conf angegebene Adresse + Port. Dort wiederum lauscht nun der SimpleAPI-Adapter ob an Port yyyyy wer was senden möchte und nimmt dann ggf. das Datenpaket an
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
die IP-Adresse der Wetterstation nirgends steht.
Dann müßte es m.M. egal sein, wenn die Wetterstation eine andere IP Adresse zugewiesen bekommt.
Lieben Dank für deine Arbeit, dein Skirpt und deine obige Erklärung. Bei mir war und ist es ein Protokollproblem, dass ich nicht nachvollziehen kann. Aber ehrlich, egal. Es funktiioniert jetzt wieder und ich kann mich um frisch laufende Projekte kümmern!
LG, mxa
-
@metaxa sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Dann müßte es m.M. egal sein, wenn die Wetterstation eine andere IP Adresse zugewiesen bekommt.
In wahrscheinlich 99.99% der Fälle ja, wenn du aber "Subnetting" betreibst/betreiben musst kommt es bei einer Fehlkonfiguration uU. dazu dass er in einem anderen Subnet landet und dann nicht ansprechbar ist bzw. er von dem Subnet nicht in das mit dem Skript-Rechner verbinden kann.
Das Thema ist für größere Installation sowieso nötig. Ich habe zwar noch paar IPs frei, mich stört aber der ganze "Mischmasch". Deswegen werde ich das auch bei Gelegenheit mal angehen und dann SmartHome-Gesumse in eigene IP-Bereiche verlegen -
Bei mir läuft jetzt alles mit InfluxDBV2. Habe auch die neusten Versionen der scripte geladen. Funktionieren auch so weit bis auf in der Wetterstatistik mit den DP´s von "Windboee". Du wurden nicht erstellt und ich kann sie auch nicht selber neuerstellen unter
0_userdata.0.Statistik.Wetter.Jahreswerte
würde nur direkt unter
0_userdata.0.Statistik
funktionieren.
javascript.0 2023-05-05 01:03:05.407 error at Template_Rekordwerte (script.js.common.WS.Wetterstatistik_SBorg:677:66) javascript.0 2023-05-05 01:03:05.407 error script.js.common.WS.Wetterstatistik_SBorg: TypeError: Cannot read properties of null (reading 'common') javascript.0 2023-05-05 01:03:05.406 warn script.js.common.WS.Wetterstatistik_SBorg: Object "0_userdata.0.Statistik.Wetter.Rekordwerte.value.Windboee" does not exist javascript.0 2023-05-05 01:03:05.406 warn at Template_Rekordwerte (script.js.common.WS.Wetterstatistik_SBorg:676:16) javascript.0 2023-05-05 01:03:05.406 warn getState "0_userdata.0.Statistik.Wetter.Rekordwerte.value.Windboee" not found (3) javascript.0 2023-05-05 01:03:00.398 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.398 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.397 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:303:5) javascript.0 2023-05-05 01:03:00.397 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1719:20) javascript.0 2023-05-05 01:03:00.397 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.397 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.397 warn at Rekordwerte (script.js.common.WS.Wetterstatistik_SBorg:662:9) javascript.0 2023-05-05 01:03:00.397 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.398 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.397 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.396 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:284:79) javascript.0 2023-05-05 01:03:00.396 warn State "0_userdata.0.Statistik.Wetter.Jahreswerte.Windboee_max" not found javascript.0 2023-05-05 01:03:00.396 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.396 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:284:12) javascript.0 2023-05-05 01:03:00.396 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.397 warn getState "0_userdata.0.Statistik.Wetter.Rekordwerte.value.Windboee" not found (3) javascript.0 2023-05-05 01:03:00.397 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:303:5) javascript.0 2023-05-05 01:03:00.397 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.397 warn State "0_userdata.0.Statistik.Wetter.Rekordwerte.value.Windboee" not found javascript.0 2023-05-05 01:03:00.397 warn at Rekordwerte (script.js.common.WS.Wetterstatistik_SBorg:663:9) javascript.0 2023-05-05 01:03:00.396 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.396 warn getState "0_userdata.0.Statistik.Wetter.Jahreswerte.Windboee_max" not found (3) javascript.0 2023-05-05 01:03:00.396 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.396 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.396 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1719:20) javascript.0 2023-05-05 01:03:00.396 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:05.407 error at Template_Rekordwerte (script.js.common.WS.Wetterstatistik_SBorg:677:66) javascript.0 2023-05-05 01:03:05.407 error script.js.common.WS.Wetterstatistik_SBorg: TypeError: Cannot read properties of null (reading 'common') javascript.0 2023-05-05 01:03:05.406 warn script.js.common.WS.Wetterstatistik_SBorg: Object "0_userdata.0.Statistik.Wetter.Rekordwerte.value.Windboee" does not exist javascript.0 2023-05-05 01:03:05.406 warn at Template_Rekordwerte (script.js.common.WS.Wetterstatistik_SBorg:676:16) javascript.0 2023-05-05 01:03:05.406 warn getState "0_userdata.0.Statistik.Wetter.Rekordwerte.value.Windboee" not found (3) javascript.0 2023-05-05 01:03:00.398 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.398 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.398 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.397 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:303:5) javascript.0 2023-05-05 01:03:00.397 warn at Rekordwerte (script.js.common.WS.Wetterstatistik_SBorg:663:9) javascript.0 2023-05-05 01:03:00.397 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1719:20) javascript.0 2023-05-05 01:03:00.397 warn State "0_userdata.0.Statistik.Wetter.Rekordwerte.value.Windboee" not found javascript.0 2023-05-05 01:03:00.397 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.397 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.397 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.397 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:303:5) javascript.0 2023-05-05 01:03:00.397 warn at Rekordwerte (script.js.common.WS.Wetterstatistik_SBorg:662:9) javascript.0 2023-05-05 01:03:00.397 warn getState "0_userdata.0.Statistik.Wetter.Rekordwerte.value.Windboee" not found (3) javascript.0 2023-05-05 01:03:00.397 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.397 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.396 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.396 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:284:79) javascript.0 2023-05-05 01:03:00.396 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1719:20) javascript.0 2023-05-05 01:03:00.396 warn State "0_userdata.0.Statistik.Wetter.Jahreswerte.Windboee_max" not found javascript.0 2023-05-05 01:03:00.396 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.396 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.396 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.396 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:284:12) javascript.0 2023-05-05 01:03:00.396 warn getState "0_userdata.0.Statistik.Wetter.Jahreswerte.Windboee_max" not found (3) javascript.0 2023-05-05 01:03:00.396 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.396 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.396 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.396 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:248:78) javascript.0 2023-05-05 01:03:00.396 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1719:20) javascript.0 2023-05-05 01:03:00.395 warn State "0_userdata.0.Statistik.Wetter.aktueller_Monat.Max_Windboee" not found javascript.0 2023-05-05 01:03:00.395 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.395 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.395 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.395 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:248:8) javascript.0 2023-05-05 01:03:00.395 warn getState "0_userdata.0.Statistik.Wetter.aktueller_Monat.Max_Windboee" not found (3) javascript.0 2023-05-05 01:03:00.395 warn at processImmediate (node:internal/timers:476:21) javascript.0 2023-05-05 01:03:00.395 warn at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/db-states-redis/lib/states/statesInRedisClient.js:322:37) javascript.0 2023-05-05 01:03:00.395 warn at change (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.js:5816:71) javascript.0 2023-05-05 01:03:00.395 warn at Object.cb (script.js.common.WS.Wetterstatistik_SBorg:227:5) javascript.0 2023-05-05 01:03:00.394 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1719:20) javascript.0 2023-05-05 01:03:00.392 warn State "0_userdata.0.Statistik.Wetter.VorTag.Windboee_max" not found
-
@chris76e Deine Datenpunkte scheinen schon älter zu sein. Beim aktuellen Skript werden die Datenpunkte korrekt angelegt, bei dir sind sie noch "falsch". Die Ordner müssen vom Typ "folder" sein, nicht "state":
Falls es sich nicht umstellen lässt musst du es direkt in den RAW-Daten auf folder ändern:
-
hab den jetzt so geändert. reicht das?
{ "common": { "name": "Werte von Gestern", "type": "folder", "role": "state" }, "native": { "name": "Werte von Gestern", "type": "folder", "role": "state" }, "type": "folder", "_id": "0_userdata.0.Statistik.Wetter.VorTag", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" }, "from": "system.adapter.admin.0", "user": "system.user.admin", "ts": 1683283802125 }
und kann ich den DP umbennen oder lieber neu anlegen mit dem richtigen Namen?
{ "common": { "name": "stärkste Windböe vom Vortag", "type": "number", "role": "state", "unit": "km/h" }, "native": { "name": "stärkste Windböe vom Vortag", "type": "number", "role": "state", "unit": "km/h" }, "type": "state", "from": "system.adapter.javascript.0", "user": "system.user.admin", "ts": 1651661223535, "_id": "0_userdata.0.Statistik.Wetter.VorTag.Windboe_max", "acl": { "object": 1636, "state": 1636, "owner": "system.user.admin", "ownerGroup": "system.group.administrator" } }
-
@chris76e sagte in [Linux Shell-Skript] WLAN-Wetterstation:
und kann ich den DP umbennen
Ist einfacher ("e" anhängen genügt), sind so 5-7 Stück aus dem Gedächtnis heraus. Das Statistik-Skript legt selektiv keine Datenpunkte an, nur neu dazugekommene oder eben alle. Wenn du die also raus löschst werden sie nicht neu angelegt (außer man ändert die Funktion im Skript).
-
Hallo @SBorg
hatte mir die Wetterstation-Dashboard_V3.json von github mal installiert und finde
einige Einstellungen bzw. Datenpunkte wie "javascript.0.Statistik.Temperatur.Außen.Min_24h"
nicht für Temperatur min/max. Ist das ein eigenes Skript von dir? -
@nashra Das dürfte sich darauf beziehen?
Das ist ein (eigentlich mittlerweile unnötiges) JavaScript. Man könnte das auch einfach in Influx V2 aggregieren. Das ist nichts weiter wie der Min-/Max-Temperaturwert eines Tages der letzten 365 Tage.
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Das ist ein (eigentlich mittlerweile unnötiges) JavaScript. Man könnte das auch einfach in Influx V2 aggregieren. Das ist nichts weiter wie der Min-/Max-Temperaturwert eines Tages der letzten 365 Tage.
Einfach aggregieren, ich weiß noch nicht mal wo ich da jetzt ansetzen müßte
-
Die beiden Datenpunkte liegen hier
javascript.0.Wetterstation.Info.Temp_Aussen_24h_min und javascript.0.Wetterstation.Info.Temp_Aussen_24h_max oder 0.userdata.....
Dann müssen die beiden Abfragen A und B geändert werden
from(bucket: "iobroker") |> range(start: v.timeRangeStart, stop: v.timeRangeStop) |> filter(fn: (r) => r._measurement == "javascript.0.Wetterstation.Info.Temp_Aussen_24h_min" and r._field == "value") |> aggregateWindow(every: v.windowPeriod, fn: last, createEmpty: false) |> yield(name: "Tiefstwert 24h")
-
@chris76e
An die hatte ich gar nicht gedacht, war jetzt so mit dem Skript beschäftigt.
Habe die Quellen ausgetauscht und läuft. -
Kleiner funfact am Rande: D. Trump hat tatsächlich Recht
Die globale Erderwärmung ist "nur eine Erfindung der Chinesen"...Hier der Beweis :
[Ironie /OFF]
-
ist mir heute erst aufgefallen, habe am 3/4 Mai auf Influxdb 2 gewechselt, habe die Datenpunkte unter javascript.0 behalten. Jetzt werden in den DP´s von
javascript.0.Wetterstation.Info.Temp_Aussen_24h_max und min
nichts mehr geschrieben, sondern in den DP´s
javascript.0.Wetterstation.Info.Temp_Aussen_Heute_max und min
Hast du da was geändert?
-
@chris76e sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Hast du da was geändert?
Für den Wechsel V2.v --> V3.x ja, denn die Influx-Abfrage basiert ja nun auf Flux. An der Funktion, nein.
Die beiden (oder vier) DPs sind unterschiedlich was den Zeitraum angeht.- Heute: Mitternacht bis "jetzt" / aktuell 12:30 Uhr, wäre also alles von Heute 0:00 Uhr bis 12:30 Uhr
- 24h : "jetzt" minus 24 Stunden /aktuell 12:30 Uhr, wäre also alles von Gestern 12:30 Uhr bis Heute 12:30 Uhr
Je nach Temperaturverlauf können die Daten auch identisch sein.
Funktioniert aber beides (hier 24h_min):
* Edit * ev. mal das Script restarten.
-
hmm,
warum wird denn bei mir keine Daten in den DP´s von:
javascript.0.Wetterstation.Info.Temp_Aussen_365t_max
geschrieben???
Habe diese Script gestartet und gestoppt damit die DP´s angelegt werden
//Wetterstation Datenpunkte anlegen V3.0.0 let DP = "javascript.0.Wetterstation."; let WH31 = 0; // Anzahl der WH31/WH25 Sensoren (max. 1 Stück) let WS90 = 0; // Anzahl der WS90 Sensoren (max. 1 Stück) let DP10 = 0; // Anzahl der DP10/WN35 Sensoren (max. 8 Stück) let DP35 = 0; // Anzahl der DP35/WN34 Sensoren (max. 8 Stück) let DP40 = 0; // Anzahl der DP40/WH32 Sensoren (max. 1 Stück) let DP50 = 0; // Anzahl der DP50/WH31 Sensoren (max. 8 Stück) let DP60 = 0; // Anzahl der DP60/WH57 Sensoren (max. 1 Stück) let DP70 = 0; // Anzahl der DP70/WH55 Sensoren (max. 4 Stück) let DP100 = 0; // Anzahl der DP100/WH51 Sensoren (max. 8 Stück) let DP200 = 0; // Anzahl der DP200/WH43 Sensoren (max. 4 Stück) let DP250 = 0; // Anzahl der DP250/WH45 Sensoren (max. 1 Stück) let DP300 = 0; // Anzahl der DP300/WS68 Sensoren (max. 1 Stück) let BR7009999 = 0; // Anzahl der Thermo-Hygro-7Ch-Sensoren (max. 4 Stück) let FT0300 = 0; // Anzahl der FT0300 Sensoren (max. 1 Stück) //Ende der User-Einstellungen -------------------
und diese Version von der Wetterstatistik
/* Wetterstation-Statistiken holt die Messdaten aus einer InfluxDB V2 und erstellt eine Monats-, Vorjahresmonat- und Rekordwerte-Statistik Wichtig: funktioniert nur mit der Default-Datenstruktur des WLAN-Wetterstation-Skriptes! Auch keine Aliase unter Influx nutzen! (c)2020-2023 by SBorg v2.0.2 - 02.03.2023 ~Bugfix fehlender Vorjahresmonat (Fix Issue #58) V2.0.1 - 22.02.2023 ~Bugfix Influx-Abfrage "Wind" (@Latzi) ~Bugfix fester Datenpunkt auf "javascript.0..." bei Trockenperiode V2.0.0 - 15.02.2023 ~Umstellung auf Influx V2 +Fix "{ack=true}" bei Wüstentage, Tropennächte und Regentage in VorJahres-Anzeige ~Windboe nach Windboee umbenannt V1.3.2 - 03.02.2023 ~Verbesserung des JSON-handlings "VorJahr" (@Boronsbruder) V1.3.1 - 01.02.2023 ~Bugfix keine Daten für Vorjahresmonatswerte (Fix Issue #54) V1.3.0 - 09.09.2022 +Regentage (Issue #40) V1.2.0 - 04.08.2022 +Wüstentage und Tropennächte V1.1.3 - 01.08.2022 +Rekordwerte auch bei Einstellung "LAST_RAIN=DATUM [+UNIX]" in der wetterstation.conf V1.1.2 - 19.06.2022 ~mögliche "Null"-Werte bei "Regenmenge Vortag" und "Windböe" gefixt (Fix Issue #35) V1.1.1 - 02.05.2022 ~Rework JSON-Management V1.1.0 - 02.04.2022 ~Bugfixing fehlender Vortag am 01. des Monats (Fix Issue #32) ~Korrektur Reset der Monatswerte V1.0.1 - 18.12.2021 ~Bugfixing "error: TypeError: Cannot read property '0' of null" ~Wechsel zu axios V1.0.0 - 02.10.2021 ~Bugfixing Werte VorJahresMonat +Kompatibilität mit JSC 3.3.x hergestellt (Änderung JSON -> Array) ~Rekordwerte werden nun korrekt am Tag des Ereignisses gespeichert V0.2.2 - 01.02.2021 ~Bugfixing Regenmenge Jahr + Monat V0.2.1 - 21.01.2021 ~Bugfixing Rekordwerte Spitzenhöchst-/-tiefstwert V0.2.0 - 15.01.2021 ~Bugfixing Benennung DPs / Korrektur Regenmenge V0.1.9 - 09.01.2021 +Regenmenge eines kpl. Monats im Jahr und Rekord V0.1.8 - 08.01.2021 +max. Windböe für Gestern und Jahres-/Rekordwerte V0.1.7 - 03.01.2021 ~Fix für fehlerhafte/fehlende Speicherung Jahreswerte + Trockenperiode V0.1.6 - 30.12.2020 +Summe "Sommertage", "heiße Tage", "Frosttage", "Eistage" und "sehr kalte Tage" für das gesamte Jahr V0.1.5 - 29.12.2020 +Summe "kalte Tage" und "warme Tage" für das gesamte Jahr V0.1.4 - 26.12.2020 +max. Regenmenge pro Tag für Jahres-/Rekordwerte V0.1.3 - 11.11.2020 +Rekordwerte V0.1.2 - 14.10.2020 ~Fix "NaN" bei Regenmenge Monat V0.1.1 - 12.10.2020 +AutoReset Jahresstatistik V0.1.0 - 08.10.2020 +DP für Statusmeldungen / Reset Jahresstatistik / AutoDelete "Data" +ScriptVersion / Update vorhanden / UpdateCheck abschaltbar +Jahresstatistik Min-/Max-/Durchschnittstemperatur/Trockenperiode V0.0.7 - 19.09.2020 +Min.-/Max.-/Durchschnittstemperatur vom Vortag V0.0.6 - 18.09.2020 +Regenmenge Monat V0.0.5 - 17.09.2020 +Gradtage Vorjahr V0.0.4 - 16.09.2020 +Eistage (Max. unter 0°C) / sehr kalte Tage (Min. unter -10°C) ~Frosttage (Korrektur: Tiefstwert unter 0°C) V0.0.3 - 15.09.2020 +Frosttage (Min. unter 0°C) / kalte Tage (Max. unter 10°C) V0.0.2 - 12.09.2020 +warme Tage über 20°C / Sommertage über 25°C / heiße Tage über 30°C V0.0.1 - 11.09.2020 erste Beta + Temp-Min/Temp-Max/Temp-Durchschnitt/max. Windböe/max. Regenmenge pro Tag ToDo: --- known issues: keine */ // *** User-Einstellungen ********************************************************************************************************************************** const WET_DP='javascript.0.Wetterstation'; // wo liegen die Datenpunkte mit den Daten der Wetterstation [default: 0_userdata.0.Wetterstation] const INFLUXDB_INSTANZ='0'; // unter welcher Instanz läuft die InfluxDB [default: 0] const INFLUXDB_BUCKET='iobroker'; // Name des zu benutzenden Buckets const PRE_DP='0_userdata.0.Statistik.Wetter'; // wo sollen die Statistikwerte abgelegt werden. Nur unter "0_userdata" oder "javascript" möglich! let REKORDWERTE_AUSGABEFORMAT="[WERT] im [MONAT] [JAHR]"; /* Wie soll die Ausgabe der Rekordwerte formatiert werden (Template-Vorlage)? [WERT] = Messwert (zB. '22.42' bei Temperatur, '12' bei Tagen) [TAG] = Tag (0-31) [MONAT] = Monatsname (Januar, Februar,..., Dezember) [MONAT_ZAHL]= Monat als Zahl (01-12) [MONAT_KURZ]= Monatsname kurz (Jan, Feb,..., Dez) [JAHR] = Jahreszahl vierstellig (2020) Die 'Units' wie bspw. "°C" oder "Tage" werden direkt aus dem Datenpunkt ergänzt. [default: [WERT] im [MONAT] [JAHR] ] erzeugt als Beispiel im DP die Ausgabe: "22.42 °C im Juni 2020" */ const ZEITPLAN = "3 1 * * *"; // wann soll die Statistik erstellt werden (Minuten Stunde * * *) [default 1:03 Uhr] // *** ENDE User-Einstellungen
Sollte doch eigentlich richtig sein?