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.
    • S
      schittl @SBorg last edited by

      @sborg

      Hier der aktuelle Data-String:

      Listening on [0.0.0.0] (family 2, port 1081)
      Connection from xxx.xxx.xxx.xxx 24659 received!
      PASSKEY=xxxx&stationtype=xxxx&runtime=13729033&dateutc=2023-09-14+09:33:00&tempinf=53.06&humidityin=65&baromrelin=28.175&baromabsin=28.175&tempf=52.88&humidity=93&winddir=24&windspeedmph=0.22&windgustmph=1.12&maxdailygust=9.17&solarradiation=117.44&uv=1&rainratein=0.000&eventrainin=0.150&hourlyrainin=0.000&dailyrainin=0.043&weeklyrainin=0.150&monthlyrainin=0.673&yearlyrainin=33.012&totalrainin=33.012&temp1f=67.64&humidity1=68&temp2f=75.20&soilmoisture1=4&soilmoisture2=50&soilmoisture3=18&soilmoisture4=37&soilmoisture5=43&lightning_num=0&lightning=10&lightning_time=1692962277&leak_ch1=0&tf_ch1=73.40&wh65batt=0&batt1=0&batt2=0&soilbatt1=1.5&soilbatt2=1.5&soilbatt3=1.5&soilbatt4=1.5&soilbatt5=1.5&wh57batt=5&leakbatt1=5&tf_batt1=1.58&freq=868M&model=xxxx
      

      DP30 ist temp2f & batt2 meines Erachtens

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

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

        DP30 ist temp2f & batt2 meines Erachtens

        "Leider"...
        Da haben sie leider einen Bock geschossen, wohl aus den Anfängen des Ganzen. Bei neueren Sensoren sind sie schlauer.
        Der DP30 lässt sich von der Kennung nicht von einem DP50 unterscheiden, außer dass ihm halt die Luftfeuchte fehlt.
        Da die Daten aber "on-the-fly" verarbeitet werden, habe ich keine Möglichkeit festzustellen was es nun ist, da die Luftfeuchte erst später kommt, oder halt eben nicht kommt.
        Den Datenstring im Nachgang zu patchen ist auch keine echte Option, dann kommt die ganze Kanalnummerierung durcheinander, da ich auch nicht weiß ob jemand bspw. auf Kanal1 einen DP50 hat, auf Kanal2 noch einen DP50, auf Kanal3 einen DP30...

        Es bleibt also wohl oder übel nichts anderes übrig als den DP30 als DP50 laufen zu lassen. Die überflüssigen DPs könnte man dann von Hand löschen oder halt stehen lassen, wirklich stören tun sie außer optisch nicht.

        S 1 Reply Last reply Reply Quote 0
        • S
          schittl @SBorg last edited by

          @sborg
          Das stört mich nicht. Ich hatte anfangs den Verdacht, das die Werte nicht gespeichert werden. Nun erscheinen aber die Werte. Vllt war ich zu ungeduldig 😅 Also alles gut. Haste nix zu korrigieren. DP30 ist also wie DP50. Wieder was gelernt. Schönes WE und danke

          1 Reply Last reply Reply Quote 0
          • E
            Entraax last edited by

            Funktioniert es auch mit dieser Station?
            BRESSER-MeteoChamp-HD-WLAN-Wetterstation-7-in-1-mit-verschiedenen-Anzeige-Modi

            Ich habe es heute erhalten und will es im ioBroker gerne einbinden.

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

              @entraax
              Hi, ja, sollte zumindest. Wissen tut man es allerdings erst wirklich wenn es läuft... 😉
              Da du sie eh schon hast, ist das Risiko ziemlich gering.

              Es bestehen drei Möglichkeiten:

              1. die Station unterstützt eigene Wetterserver. Dann kannst du einfach die IP + URL (siehe WiKi) von dem Rechner eingeben auf dem das Skript läuft
              2. die DNS-Anfrage umleiten (PiHole, dnsmasq,...), also die Daten die an WU geschickt werden sollten landen auf dem Rechner auf dem das Skript läuft.
              3. die Daten an AWEKAS schicken und dann mittels des (ev. bald erscheinenden) AWEKAS-Adapters abholen.
              W 1 Reply Last reply Reply Quote 0
              • E
                Entraax last edited by

                @sborg

                danke für das aufzählen der Möglichkeiten. Ich werde es mal testen.

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

                  @SBorg
                  kannst Du mir sagen was da heute Nacht schiefgelaufen ist

                  2023-10-01 01:02:12.184 - info: linux-control.0 (2530934) successful received data from Proxmox (192.168.1.13:22)
                  2023-10-01 01:03:00.082 - error: javascript.0 (2529042) Error in callback: SyntaxError: Unexpected token o in JSON at position 1
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at JSON.parse ()
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at VorJahr (script.js.Wetter.Statistik-WS:417:24)
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at Object.main (script.js.Wetter.Statistik-WS:158:4)
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at Job.job (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1617:34)
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at Job.invoke (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Job.js:171:15)
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at /opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:268:28
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at Timeout._onTimeout (/opt/iobroker/node_modules/iobroker.javascript/node_modules/node-schedule/lib/Invocation.js:228:7)
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at listOnTimeout (node:internal/timers:569:17)
                  2023-10-01 01:03:00.083 - error: javascript.0 (2529042) at processTimers (node:internal/timers:512:7)
                  2023-10-01 01:04:00.048 - info: host.ioBroker instance system.adapter.weatherunderground.0 started with pid 841580
                  

                  Node 18.18.0
                  Admin 6.10.1
                  Javascript 7.1.4
                  IOB 5.0.12

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

                    @Nashra

                    Error in callback: SyntaxError: Unexpected token o in JSON at position 1
                    

                    Ich würde behaupten, der Json den er vom Vorjahr parsen wollte, ist kein JSON (von der Formatierung), sondern ein Object?

                    Meiner sah z.B. so aus:

                    [{'Tiefstwert':2.1,'Hoechstwert':24.7,'Temp_Durchschnitt':12.14,'Max_Windboee':47.87,'Max_Regenmenge':19.304,'Regenmenge_Monat':60.51,'warme_Tage':9,'Sommertage':0,'heisse_Tage':0,'Frost_Tage':0,'kalte_Tage':0,'Eistage':0,'sehr_kalte_Tage':0}]
                    
                    1 Reply Last reply Reply Quote 0
                    • SBorg
                      SBorg Forum Testing Most Active last edited by

                      Jupp, alt bekanntes Problem. So wie es aktuell erstellt wird ist es auch kein ioB valides JSON. Das ist nur "hin- und zusammen gefrickelt" damit es "irgendwie" mit allem anderen funktioniert (zumindest mehr oder weniger).

                      Plan: korrektes JSON erstellen, Konverter für die Alt-Datensätze erstellen, um sie in korrektes JSON umzuwandeln, Skripte ggf. anpassen
                      Umsetzung: unbekannt, nicht in absehbarer Zeit meinerseits

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

                        Hi, sorry war 3 Tage im Krankenhaus, daher erst jetzt. Kein Problem @SBorg , wird ja trotzdem alles korrekt angezeigt.
                        Also ganz in Ruhe irgendwann mal wenn Du Zeit hast.

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

                          @nashra
                          Hoffe alles wieder gut, auf jeden Fall gute Besserung.

                          Also ganz in Ruhe irgendwann mal wenn Du Zeit hast.

                          Also nie ? 🤘
                          Hier "stapelt" nix mehr, das "türmt" sich schon, von wegen Arbeit und so...
                          Prio hat jetzt aktuell meine Solaranlagenerweiterung, dann steht die Klima auf der ToDo und so weiter 😉

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

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

                            @nashra
                            Hoffe alles wieder gut, auf jeden Fall gute Besserung.

                            Also ganz in Ruhe irgendwann mal wenn Du Zeit hast.

                            Also nie ? 🤘

                            Na Na Na, so war das aber jetzt auch nicht gemeint 😀

                            Hier "stapelt" nix mehr, das "türmt" sich schon, von wegen Arbeit und so...
                            Prio hat jetzt aktuell meine Solaranlagenerweiterung, dann steht die Klima auf der ToDo und so weiter 😉

                            Ok, wichtiger. Dann mal ran...

                            1 Reply Last reply Reply Quote 0
                            • V
                              viper4iob @Sugomojawe last edited by viper4iob

                              @sugomojawe said in [Linux Shell-Skript] WLAN-Wetterstation:

                              Hallo zusammen,
                              ich hätte da mal eine Frage. mein Vater hat mich mit dem ganzen Thema etwas angefixt. Er ist Amateurfunker und hat in seinem Hobbyraum eine ganze Station um Wetterbilder von Meteosat zu empfangen.
                              Aber zu meiner Frage, ich habe vor mir die Froggit HP1000SE PRO Display inkl. Innensensor + DP40 Aussen Temperatur/Luftfeuchte + DP80 Regensensor + DP300 Anemometer zu kaufen. Wie läuft das mit dem DP80 Regensensor? Der steht ja nicht in der Liste der Zusatzsensoren, wird der mit dem Display verbunden und dann so an ioBroker übermittelt oder wie kann ich mir das vorstellen?

                              Danke und liebe Grüße aus dem Westerwald
                              Michael

                              Hi,
                              ich habe von Froggit die HP1000SE PRO Single Sensor Edition und zusätzlich einen zweiten Außentemperatursensor und einen Blitzdetektor.
                              In der Single Sensor Edition ist auch der DP80 enthalten und das funktioniert ohne Probleme, er sendet also seine Werte als "regulärer Sensor" und muss nicht als zusätzlicher Sensor hinzugefügt werden.
                              In der config habe ich bei folgenden Sensoren eine 1 stehen:

                              ANZAHL_WH31=1	#Außen Thermo-Hygrometer
                              ANZAHL_DP40=1	#zusätzliches Außen Thermo-Hygrometer
                              ANZAHL_DP50=1	#Innen Thermo-Hygrometer
                              ANZAHL_DP60=1	#Blitzdetektor
                              ANZAHL_DP300=1	#Anemometer und Lichtsensor
                              
                              1 Reply Last reply Reply Quote 0
                              • Rene55
                                Rene55 @SBorg last edited by

                                @sborg Ich habe gestern (😖) festgestellt, dass die Werte von 0_userdata.0.Wetterstation.Info.Temp_Aussen_24h_max (und ähnliche) nicht da sind. Kannst du mir kurz einen Hinweis geben, wo da was falsch läuft, bzw. wann die von wem geschrieben werden? Ich blick gerade nicht mehr durch.

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

                                  @rene55 Wird aus der InfluxDB gelesen.

                                  Dazu nötig:

                                  • loggen der Außentemperatur per Influx
                                  • InfluxDB-Verbindung
                                    • Bucket
                                    • Token
                                    • Organisation
                                    • IP-Adresse und Port

                                  Falls du also was an der InfluxDB geändert haben solltest...
                                  Kleiner Test (auch im laufenden Betrieb) im Installationsverzeichnis stehen: ./wetterstation.sh --influx_test

                                  Bild 001.png

                                  Rene55 1 Reply Last reply Reply Quote 0
                                  • Rene55
                                    Rene55 @SBorg last edited by Rene55

                                    @sborg Danke, sowas hab ich gesucht. Ja, ich hatte eine andere Influx angebunden. Nach bestem Wissen sind alle Parameter richtig.
                                    Bei dem Test bekomme ich jetzt:

                                    ./wetterstation.sh: line 161: [: V3.2.0: unary operator expected
                                    Testing InfluxDB... min/max Aussentemperatur 24h: °C °C
                                    
                                    

                                    Hab nachgesehen: Alle Dateien haben intern die V3.2.0 stehen.

                                    EDIT: Ich hab die .conf neu gemacht - der unary-Fehler ist weg, sonst unverändert keine Werte!

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

                                      @rene55
                                      Schau mal

                                      1. Ob Daten in der DB sind
                                      2. Ins Log der DB, ob da nicht vielleicht der Zugriff durch das Skript zurückgwiesen wird
                                      Rene55 1 Reply Last reply Reply Quote 0
                                      • Rene55
                                        Rene55 @Boronsbruder last edited by Rene55

                                        @boronsbruder Grundsätzlich sind Daten in der DB drin. _24h_max ist leer.
                                        Log der DB??? Wo und wie?

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

                                          @rene55 Weil wir es schon mal hatten, dein Token in der wetterstation.conf endet mit "==" ?
                                          Da das Ganze URL basierend ist und ich noch nicht überall korrigiert habe, hast du ev. ein Sonderzeichen (auch Leerzeichen) im Bucket bzw. Organisation? Soweit ich mich noch erinnere ist die Organisation bei Influx auch case sensitiv.

                                          Standardmäßig loggt InfluxDB ins syslog. Ich weiß aber nicht ob er da fehlende Rechte, User etc. pp. von Influx mit loggt.
                                          Mach noch mal den Influx-Test von oben gefolgt von einem sudo dmesg|tail ob da was von Influx steht.

                                          1 Reply Last reply Reply Quote 0
                                          • Rene55
                                            Rene55 last edited by

                                            @sborg Das stimmt. Mein Token enden mit "==". Ich hab gerade den Befehl von oben nochmal ausgeführt und danach den dmesg gemacht dmesg: read kernel buffer failed: Operation not permitted.

                                            Ich hatte extra ein Bucket für "weather" erstellt. Unter den meisten Einträgen sind Werte drin. Nur eben nicht bei den min/max-Werten.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            892
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

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