NEWS
[Linux Shell-Skript] WLAN-Wetterstation
-
@sborg said in [Linux Shell-Skript] WLAN-Wetterstation:
@viper4iob Ich habe jetzt mal die beiden 10min-Werte eingebaut, in der Simulation funktioniert es auch.
Wenn ich es schaffe lade ich es noch heute zum testen auf GitHub hoch
...spätestens (hoffentlich) dann morgen...Vielen Dank für die schnelle Umsetzung.
Dann hätte ich doch noch mal eine Idee. Ich habe mir mal die 10 min Durchschnittswerte angeschaut.
Und gerade bei der Windrichtung bügelt das das extreme Schwanken der Fahne durch verwirbelte Luft oder vielleicht schlechtes Design ganz gut aus. In einem Graphen sieht es auf jeden Fall deutlich besser aus.
Die Frage wäre jetzt, ob man eine Option in die config einbauen könnte, dass zu den externen Diensten wie wetter.com oder OpensenseMap ... statt dem normalen Wert der 10 min Wert übertragen wird. Für die Windrichtung würde das Sinn machen, denke ich. Bei der Wind-Geschwindigkeit bin ich mir nicht so sicher. Eventuell macht es Sinn für beide Werte eine getrennte Option zu haben. Dann kann das jeder selbst entscheiden.
Ich sammle jetzt mal bis morgen die Daten, dann kann ich vielleicht mal Screenshots von Graphen aus iobroker im Vergleich zeigen.@viper4iob Ich überlege jetzt schon einige Zeit. Parameter in der conf wäre zwar am flexibelsten, aber es sind eigentlich auch schon genügend vorhanden (für die Rest-API kommen ja auch wieder neue hinzu).
Ich denke weiter, was meint denn der Rest?
Ich könnte die letzten 10 Minuten (bzw. zB 20 Werte) im RAM halten (paar kB und der Adapter kommt eh mit <10MB RAM aus) und daraus immer einen Mittelwert bilden für die Stationen die es nicht selbst ermitteln.
Ich sehe mein Windfähnchen immer "propellern", da ist alle 30 Sekunden ein Momentanwert auch eher nichtssagend. -
@negalein
leider wieder was vergessen, oben schon geändert....und "ausführbar" machen mittels
chmod +x ./ws_updater.betaBeim http(s) der Rest-API URL bin ich mir gerade nicht sicher. Müsste eigentlich mittels "https" laufen.
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Beim http(s) der Rest-API URL bin ich mir gerade nicht sicher. Müsste eigentlich mittels "https" laufen.
mit
httpist die Meldung gekommen, dass es angelegt wurde.
In0.userdatawar es aber nicht da.mit
httpsfunktioniert es perfekt.Lege neues Object im ioBroker an: 0_userdata.0.Test_RestAPI.Info.Meldungen dietpi@DietPi:/home/iobroker$ ./ws_updater.beta --test ┌────────────────────────┐ │ │ │ WS-Updater V2.15.0 │ │ │ └────────────────────────┘ Lege neues Object im ioBroker an: 0_userdata.0.Test_RestAPI.Info.Meldungen Fehlermeldung beim Anlegen des Datenpunktes: {"error":"Object already exists","id":"0_userdata.0.Test_RestAPI.Info.Meldungen"} dietpi@DietPi:/home/iobroker$
-
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Beim http(s) der Rest-API URL bin ich mir gerade nicht sicher. Müsste eigentlich mittels "https" laufen.
mit
httpist die Meldung gekommen, dass es angelegt wurde.
In0.userdatawar es aber nicht da.mit
httpsfunktioniert es perfekt.Lege neues Object im ioBroker an: 0_userdata.0.Test_RestAPI.Info.Meldungen dietpi@DietPi:/home/iobroker$ ./ws_updater.beta --test ┌────────────────────────┐ │ │ │ WS-Updater V2.15.0 │ │ │ └────────────────────────┘ Lege neues Object im ioBroker an: 0_userdata.0.Test_RestAPI.Info.Meldungen Fehlermeldung beim Anlegen des Datenpunktes: {"error":"Object already exists","id":"0_userdata.0.Test_RestAPI.Info.Meldungen"} dietpi@DietPi:/home/iobroker$
@negalein Supi, danke für das testen. Dann können sich zukünftig Rest-API Nutzer freuen (für die kommende V2.15.0 ist es dafür leider schon zu spät)

Bei falschem Protokoll kommt leider keinerlei Fehlermeldung zurück, dafür aber überhaupt nix. Auf "nix" kann ich aber reagieren:

-
Hallo,
Zur Info:
ich konnte heute meine Froggit WH6000Pro erfolgreich einbinden.Gruß
Mugel80@mugel80 Danke für die Rückmeldung und kommt gleich mit in die Liste

Willkommen bei den Wetterfröschen

-
@mugel80 Danke für die Rückmeldung und kommt gleich mit in die Liste

Willkommen bei den Wetterfröschen

Vis & Kompass:
Bei der Neugestaltung meiner Wetterdaten Vis, benutue ich das Compass Widget.
Leider wir das nach einigen Minuten fehkerhaft und zeigt eine Verschiebung:
Tritt beim Firefox 102.0.1 (64-Bit) unter MacOS auf, der der aktuelle Safari 15.15 am MBPro hat kein Problem damit auch beim MS Edge 103.0.1264.51 unter OSX habe ich kein Problem festgestellt.
Ist also definitiev ein browserabhängiges Problem. Leider hab ich im Moment keinen Wondowsrechner zur Verfügung und kann das mit dem FF leider nicht testen.
-
Vis & Kompass:
Bei der Neugestaltung meiner Wetterdaten Vis, benutue ich das Compass Widget.
Leider wir das nach einigen Minuten fehkerhaft und zeigt eine Verschiebung:
Tritt beim Firefox 102.0.1 (64-Bit) unter MacOS auf, der der aktuelle Safari 15.15 am MBPro hat kein Problem damit auch beim MS Edge 103.0.1264.51 unter OSX habe ich kein Problem festgestellt.
Ist also definitiev ein browserabhängiges Problem. Leider hab ich im Moment keinen Wondowsrechner zur Verfügung und kann das mit dem FF leider nicht testen.
@tritor
Ich setzte dieses Widget ein, welches bisher ohne Probleme funktioniert:[{"tpl":"tplCGCompas","data":{"g_fixed":true,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","minValue":"0","maxValue":"360","factor":"1","valueOffset":"0","hCount":"1","majorTicks":"N,NO,O,SO,S,SW,W,NW,N","minorTicks":"22","strokeTicks":"false","animation":"true","animationDuration":"1000","colorPlate":"#222","colorMajorTicks":"#f5f5f5","colorMinorTicks":"#ddd","colorNumbers":"#ccc","colorNeedle":"rgba(240,128,128,1)","colorNeedleEnd":"rgba(255,160,122,.9)","colorBorderOuter":"#ccc","colorBorderOuterEnd":"#ccc","colorNeedleShadowDown":"#222","needleType":"line","needleStart":"75","needleEnd":"99","needleWidth":"3","borders":"true","borderOuterWidth":"4","borderMiddleWidth":"0","borderInnerWidth":"0","borderShadowWidth":"0","valueBox":true,"valueTextShadow":"false","ticksAngle":"360","startAngle":"180","colorNeedleCircleOuter":"#ccc","needleCircleSize":"15","needleCircleOuter":"false","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis.0/Weatherman/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.0/Weatherman/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.0/Weatherman/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,"oid":"0_userdata.0.Wetterstation.Windrichtung","units":"°","title":"Wind","valueDec":"0","name":"Windrichtung"},"style":{"left":"245px","top":"34px"},"widgetSet":"canvas-gauges"}] -
hättest du die Windrose als gesamten Widgetcode zur Verfügung?
Auf welchem Wideget basiert es? Ich hätte versucht mit dem Kompass-Widget zu arbeiten, bekomme aber keine Grafik rein. -
hättest du die Windrose als gesamten Widgetcode zur Verfügung?
Auf welchem Wideget basiert es? Ich hätte versucht mit dem Kompass-Widget zu arbeiten, bekomme aber keine Grafik rein. -
eh so einfach .. danke, habs hinbekommen
-
eh so einfach .. danke, habs hinbekommen
-
Mal ein kleiner "Schwenk" aus dem Alltag des Devs. Wie berechnet man die durchschnittliche Windrichtung von sagen wir 20 Messwerten?
Vor dem "spoilern" mal kurz darüber nachdenken, dann spoilern und staunen

Wer mir das erklärt, dem "nogger ich einen"
-
Mal ein kleiner "Schwenk" aus dem Alltag des Devs. Wie berechnet man die durchschnittliche Windrichtung von sagen wir 20 Messwerten?
Vor dem "spoilern" mal kurz darüber nachdenken, dann spoilern und staunen

Wer mir das erklärt, dem "nogger ich einen"
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Wer mir das erklärt, dem "nogger ich einen"

Da hast du absolut recht - net easy, da muß man schon ein wenig rechnen.
Das gab es schon mal im Loxone Forum und da war ein Link auf https://en.wikipedia.org/wiki/Yamartino_method -
@speedy sagte in [Linux Shell-Skript] WLAN-Wetterstation:
da die Fehlermeldung keine Anzeichen liefert, wo der "parse error" entsteht, kann ich nicht wirklich weitersuchen.
Der entsteht "einfach" dadurch, dass keine Daten zum verarbeiten da sind und man mathematisch nicht durch "0" teilen kann/darf (oder wie das war). An der Stelle also alles iO.
Dein Messwerteblock ist aber kpl. leer, es kommen also keine Daten von deinem Display/Gateway. Dafür spricht auch Kommunikationsfehler
Nicht falsch verstehen, ist wie beim Auto das nicht fährt und darauf die Frage Treibstoff haben sie aber im Tank?, aber genau an die Installationsanleitung im Wiki gehalten? 99% der Fehler sind falscher "Pfad" in der App/oder falsche IP-Adresse (es muss wirklich die sein auf dem das Skript läuft. Das kann der ioB-Rechner sein, muss aber nicht
). Danach folgt falscher Port (der muss in App und conf identisch sein), oder Port ist nicht frei (solange das Skript/Service nicht läuft darf ein sudo netstat -tulpen|grep 9999kein Ergebnis liefern)
-
- Versuch: Port 1081 frei
-
- Versuch: Port 1080 belegt durch "nc" (logo, dort läuft das Skript
)
- Versuch: Port 1080 belegt durch "nc" (logo, dort läuft das Skript
@sborg
Hallo sborg,sorry, aber habe erst jetzt wieder Zeit gefunden, danke für deine Antwort.
Ich bin die ganze Konfiguration nochmals durchgegangen und konnte keinen Fehler finden.
Die IP-Adressen, Ports und Pfade sind korrekt. Das Scritp läuft auch:psw@iobroker:~$ sudo netstat -tulpen|grep 9999 [sudo] Passwort für psw: tcp 0 0 0.0.0.0:9999 0.0.0.0:* LISTEN 1001 12990328 11270/io.sainlogic. psw@iobroker:~$Aber eine Fehlermeldung bleibt:
./wetterstation.sh --debug WLAN-Wetterstation V2.14.0 - (c)2019-2022 by SBorg Config-Version: V2.14.0 Sub-Version : V2.14.0 'bc' installiert: [✓] 'jq' installiert: [✓] 'nc' in der Openbsd-Variante installiert: [✓] 'netcat' in Openbsd-Variante aktiv, alles korrekt [✓] Connection to 192.168.1.8 8087 port [tcp/*] succeeded! jq: error (at <stdin>:7): Cannot iterate over null (null) jq: error (at <stdin>:7): Cannot iterate over null (null) Messwerteblock: Nicht alle Werte werden unterstützt (abhängig vom Modell der Wetterstation und dem verwendeten Protokoll)! Temperatur Innen : °C Temperatur Aussen : °C Taupunkt : °C Gefühlte Temperatur : °C Luftfeuchte Innen : % Luftfeuchte Aussen : % Windgeschwindkeit : km/h Windböengeschwindigkeit : km/h max. Windböe : km/h Windrichtung : ° Windrichtung : Luftdruck absolut : hPa Luftdruck relativ : hPa Regenrate : mm/h Regenstatus : Regen seit Regenbeginn : mm Regen Stunde : mm Regen Tag : mm Regen Woche : mm Regen Monat : mm Regen Jahr : mm Regen Gesamt : mm Sonnenstrahlung : W/m² UV-Index : Zeitstempel : Firmware : Batteriestand: : Gateway-Modell : Zusatzsensoren: Datenstring für ioBroker: DATA von Wetterstation: Debug VAR: Installationsverzeichnis: /home/iobroker IPP: 192.168.1.8:8087 WS_PORT: 9999 WS_POLL: 20 PRE_DP: javascript.0.Wetterstation WEB: HTTP WS_PROT: Ecowitt DP35/40/50/60/70/100/200/250/300: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 WH31: 0 Script-Version: V2.14.0 Config-Version: V2.14.0 Sub-Version: V2.14.0 Kommunikationsfehler! root@iobroker:/home/iobroker#Was ich nicht verstehen kann ist, dass er eine Verbindung zum Simple-RESTful aufbauen kann, aber dann keine Daten erhält oder findet. Wo sollten diese sein?
soweit ich es verstanden habe, holt sich das Script die Daten über den RESTful Adapter, woher bekommt diese die Daten?Bin ratlos....
Liegt es evtl. daran, dass meine Sainlogic keinen Scheduler Mode kann?
D.h. es funktioniert nur der Listener... -
-
@speedy
Hast du den sainlogic-Adapter parallel laufen? Falls ja, das funktioniert nicht - schalte ihn ab -
@sborg sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Wer mir das erklärt, dem "nogger ich einen"

Da hast du absolut recht - net easy, da muß man schon ein wenig rechnen.
Das gab es schon mal im Loxone Forum und da war ein Link auf https://en.wikipedia.org/wiki/Yamartino_method@tritor sagte in [Linux Shell-Skript] WLAN-Wetterstation:
net easy, da muß man schon ein wenig rechnen.
...wenn es dann auch noch 40+ Jahre her ist, dass man das mal in der Schule gelernt (und bis auf jetzt nie wieder gebraucht) hat.
Der erste richtige "run" sieht vielversprechend aus:

Windrichtung (Array) | Anzahl der Datensätze im Array | gemittelter Winkel
Man sieht nach dem Start wie sich das Array mit den Messwerten langsam füllt. Dann mit dem 20. Messwert die RRD zum tragen kommt. 1. (=ältester) raus, das ganze Array um "1" nach links verschieben und den neuen Messwert als letzten Wert hinten anhängen.Hier kann man es auch gut erkennen:

Obwohl die Windrichtung von 357° nach 19° dreht, wird der Winkel größer. Muss ja, denn es ist einen tucken östlicher als Norden, dann muss der Gesamtwert auch mehr gen Norden wandern.
Ich logge erst seit ~3h, ist aber wesentlich weniger Gezappel und wir haben meist "Nordwind":

-
@sborg
Hallo sborg,sorry, aber habe erst jetzt wieder Zeit gefunden, danke für deine Antwort.
Ich bin die ganze Konfiguration nochmals durchgegangen und konnte keinen Fehler finden.
Die IP-Adressen, Ports und Pfade sind korrekt. Das Scritp läuft auch:psw@iobroker:~$ sudo netstat -tulpen|grep 9999 [sudo] Passwort für psw: tcp 0 0 0.0.0.0:9999 0.0.0.0:* LISTEN 1001 12990328 11270/io.sainlogic. psw@iobroker:~$Aber eine Fehlermeldung bleibt:
./wetterstation.sh --debug WLAN-Wetterstation V2.14.0 - (c)2019-2022 by SBorg Config-Version: V2.14.0 Sub-Version : V2.14.0 'bc' installiert: [✓] 'jq' installiert: [✓] 'nc' in der Openbsd-Variante installiert: [✓] 'netcat' in Openbsd-Variante aktiv, alles korrekt [✓] Connection to 192.168.1.8 8087 port [tcp/*] succeeded! jq: error (at <stdin>:7): Cannot iterate over null (null) jq: error (at <stdin>:7): Cannot iterate over null (null) Messwerteblock: Nicht alle Werte werden unterstützt (abhängig vom Modell der Wetterstation und dem verwendeten Protokoll)! Temperatur Innen : °C Temperatur Aussen : °C Taupunkt : °C Gefühlte Temperatur : °C Luftfeuchte Innen : % Luftfeuchte Aussen : % Windgeschwindkeit : km/h Windböengeschwindigkeit : km/h max. Windböe : km/h Windrichtung : ° Windrichtung : Luftdruck absolut : hPa Luftdruck relativ : hPa Regenrate : mm/h Regenstatus : Regen seit Regenbeginn : mm Regen Stunde : mm Regen Tag : mm Regen Woche : mm Regen Monat : mm Regen Jahr : mm Regen Gesamt : mm Sonnenstrahlung : W/m² UV-Index : Zeitstempel : Firmware : Batteriestand: : Gateway-Modell : Zusatzsensoren: Datenstring für ioBroker: DATA von Wetterstation: Debug VAR: Installationsverzeichnis: /home/iobroker IPP: 192.168.1.8:8087 WS_PORT: 9999 WS_POLL: 20 PRE_DP: javascript.0.Wetterstation WEB: HTTP WS_PROT: Ecowitt DP35/40/50/60/70/100/200/250/300: 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 WH31: 0 Script-Version: V2.14.0 Config-Version: V2.14.0 Sub-Version: V2.14.0 Kommunikationsfehler! root@iobroker:/home/iobroker#Was ich nicht verstehen kann ist, dass er eine Verbindung zum Simple-RESTful aufbauen kann, aber dann keine Daten erhält oder findet. Wo sollten diese sein?
soweit ich es verstanden habe, holt sich das Script die Daten über den RESTful Adapter, woher bekommt diese die Daten?Bin ratlos....
Liegt es evtl. daran, dass meine Sainlogic keinen Scheduler Mode kann?
D.h. es funktioniert nur der Listener...@speedy sagte in [Linux Shell-Skript] WLAN-Wetterstation:
tcp 0 0 0.0.0.0:9999 0.0.0.0:* LISTEN 1001 12990328 11270/io.sainlogic.
@latzi sagte in [Linux Shell-Skript] WLAN-Wetterstation:
Falls ja, das funktioniert nicht - schalte ihn ab
Jupp, ein Dienst auf einem Port.
@speedy sagte in [Linux Shell-Skript] WLAN-Wetterstation:
muss ich es überlesen haben
Jepp

- Port: Die Portnummer ist innerhalb des zulässigen Bereichs beliebig wählbar, muss aber frei* sein.
Ok, es steht nicht explizit der Adapter dabei, dann müsste ich aber auch jedes Programm etc. nennen, denn wo man was auf welchem Port laufen lässt ist dem Anwender überlassen.
-
ist mir gerade aufgefallen
State value to set for "javascript.0.Wetterstation.Info.Station_Batteriestatus" has to be type "string" but received type "number"@negalein Das wird nur noch bei dir so sein, der ist seit 21.01.2021 schon "number"

createState(DP+"Info.Station_Batteriestatus" , 0, {name: "Batteriestatus [0=OK, 1=Alarm]", type: "number", role: "value" });(Gleiches Thema wie beim "Name" die "Bezeichnung 0 und 1...")
Stell ihn einfach von Zeichenkette auf Zahl um und Ruhe ist



