Skip to content
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
Logo
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. WLAN-Wetterstation in ioBroker direkt einbinden

NEWS

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    8.1k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.8k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.1k

WLAN-Wetterstation in ioBroker direkt einbinden

Scheduled Pinned Locked Moved ioBroker Allgemein
wlan-wetterstationadapter
134 Posts 21 Posters 39.5k Views 28 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • LatziL Latzi

    @SBorg sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

    Eine Möglichkeit wäre bspw. ein Raspberry PI

    Das trifft sich schon mal gut, darauf läuft mein ioBroker 👍
    Leider sind dort meine System-Kenntnisse sehr bescheiden 😞 ich arbeite aber an einer Verbesserung

    Der spannt ein WLAN xxx auf und ist per RJ-45 mit dem Netzwerk verbunden

    In den Einstellungen der Wetterstation kann direkt eine IP-Adresse des "eigenen Servers" eingegeben werden (läuft parallel zu WUG), somit sendet die Station schon mal in die richtige Richtung und somit ist das Extra-WLAN am PI meiner Ansicht nicht nötig, oder?

    Leider verstehe ich beim Rest des von dir Gesagten nur Bahnhof 😵

    SBorgS Offline
    SBorgS Offline
    SBorg
    Forum Testing Most Active
    wrote on last edited by
    #5

    Ich würde erst mal klein anfangen, denn
    @Latzi sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

    In den Einstellungen der Wetterstation kann direkt eine IP-Adresse des "eigenen Servers" eingegeben werden

    ist schon mal "easy going". Nur eine IP oder auch einen Port? Dann trage dort mal die IP (+ ggf. einen freien Port) deines PI ein. Am PI gibst du dann im Terminal mal ein:

    nc -lv Port
    

    Port = den du in der Station eingegeben hast, oder falls dies nicht möglich war, dann 80
    Also bspw: nc -lv 80
    Dann sollte nach spätestens 25 Sekunden ein Datenpaket kommen. Beendet sich das nicht (was es eigentlich nach einem Paket sollte) einfach STRG + C drücken.
    ...und ja, damit würde man sich WLAN + (extra)PI sparen 😁

    LG SBorg ( SBorg auf GitHub)
    Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

    1 Reply Last reply
    1
    • LatziL Online
      LatziL Online
      Latzi
      wrote on last edited by
      #6

      @SBorg sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

      nc -lv Port

      @SBorg das ist ja Weltklasse!!! 🙌 💪

      Ich habe in den Einstellungen der Wetterstation die IP des Pi eingetragen und eine Station-ID sowie ein Passwort festgelegt, den Port hätte ich ändern können, hab ich einstweilen auf 80 belassen (Vorbelegung) auch das Sendeintervall ist einstellbar (derzeit 60 sek) und das geschah:

      Eingabe:

      sudo nc -lv 80
      

      Ergebnis:

      Listening on [0.0.0.0] (family 2, port 80)
      Connection from 10.0.0.35 1840 received!
      GET /weatherstation/updateweatherstation.php?ID=ITRAGW1&PASSWORD=LATZI&indoortempf=75.2&tempf=40.8&dewptf=39.0&windchillf=40.8&indoorhumidity=42&humidity=94&windspeedmph=2.9&windgustmph=4.5&winddir=236&absbaromin=28.308&baromin=30.095&rainin=0.000&dailyrainin=0.012&weeklyrainin=0.201&monthlyrainin=1.673&solarradiation=0.00&UV=0&dateutc=2019-12-25%2005:11:31&softwaretype=EasyWeatherV1.4.4&action=updateraw&realtime=1&rtfreq=5 HTTP/1.0
      Host: 10.0.0.210
      Accept:*/*
      Connection: Close
      
      

      Scheint als werden die gesamten Daten übertragen, die Einheiten sind noch nicht umgerechnet, das ist jedoch das geringste Problem.

      Jetzt wird´s so richtig interessant für mich, stellt sich für mich die Frage, wie bekomme ich die empfangene Datenstruktur in den ioBroker????

      B 1 Reply Last reply
      0
      • H Offline
        H Offline
        hitel
        wrote on last edited by
        #7

        Das könnte eine Lösung sein:

        FOSHKplugin

        Dieses Plugin bindet verschiedene Wetterstationen des Hersteller Fine Offset Electronics (FOSHK) an einen Miniserver über UDP an.
        Entwickelt wurde das Plugin für und mit einem Froggit DP1500 das baugleich auch unter dem Namen Ecowitt GW1000 verkauft wird.

        https://www.loxwiki.eu/plugins/servlet/mobile?contentId=60557618#content/view/60557618

        Oder

        Weewx

        http://www.weewx.com/ und Mqtt Plugin?

        Was meint ihr dazu?

        1 Reply Last reply
        1
        • OliverIOO Offline
          OliverIOO Offline
          OliverIO
          wrote on last edited by
          #8

          wenn man kein mqtt möchte oder gar weitere tools einsetzen möchte, wird man einen Adapter bauen müssen, der die Serverfunktionalität anbietet und die Daten der Wetterstation annehmen kann.
          Wahrscheinlich wird man sogar relativ viel code vom mqtt-plugin übernehmen können.

          Meine Adapter und Widgets
          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
          Links im Profil

          1 Reply Last reply
          0
          • SBorgS Offline
            SBorgS Offline
            SBorg
            Forum Testing Most Active
            wrote on last edited by
            #9

            So habe ich mir das auch vorgestellt ^^
            Man kann nun eine bash nutzen, ein Perl-, Python-Script (oä.), Telegraf oder what else.
            bash wäre bspw. recht simpel:

            #!/bin/bash   
            
            while true
            do
              DATA=`nc -lv 80|grep GET`
              
               TEMP_INNEN=$(echo ${DATA}|cut -d'&' -f3 | cut -d"=" -f2)
               TEMP_INNEN=`echo "scale=2;(${TEMP_INNEN}-32)*5/9" | bc -l`
               echo Temperatur Innen: $TEMP_INNEN °C
            done
            

            Das liefert die Innentemperatur und rechnet sie in °C um. Mittels "curl" und dem ioB Simple-API-Adapter landet es dann als Datenpunkt im ioB.

            LG SBorg ( SBorg auf GitHub)
            Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

            LatziL 1 Reply Last reply
            1
            • SBorgS SBorg

              So habe ich mir das auch vorgestellt ^^
              Man kann nun eine bash nutzen, ein Perl-, Python-Script (oä.), Telegraf oder what else.
              bash wäre bspw. recht simpel:

              #!/bin/bash   
              
              while true
              do
                DATA=`nc -lv 80|grep GET`
                
                 TEMP_INNEN=$(echo ${DATA}|cut -d'&' -f3 | cut -d"=" -f2)
                 TEMP_INNEN=`echo "scale=2;(${TEMP_INNEN}-32)*5/9" | bc -l`
                 echo Temperatur Innen: $TEMP_INNEN °C
              done
              

              Das liefert die Innentemperatur und rechnet sie in °C um. Mittels "curl" und dem ioB Simple-API-Adapter landet es dann als Datenpunkt im ioB.

              LatziL Online
              LatziL Online
              Latzi
              wrote on last edited by
              #10

              @SBorg das klingt schon mal richtig interessant, mir ist zwar noch nicht klar, was in dem bash passiert - muss mich damit aber erst auseinandersetzen. Vielen Dank für deine bisherigen Bemühungen 👍 , ich werde da aber sich noch mit einigen Fragen anklopfen.

              @SBorg sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

              ioB Simple-API-Adapter

              Meinst du damit diesen Adapter?
              f6406f83-2b1e-4465-925b-1c2041e7cb18-grafik.png

              1 Reply Last reply
              0
              • LatziL Online
                LatziL Online
                Latzi
                wrote on last edited by
                #11

                @SBorg schaut mit den Daten schon mal gut aus und es ist so simpel, dass den Code sogar ich verstehe 👍

                Listening on [0.0.0.0] (family 2, port 80)
                Connection from 10.0.0.35 21364 received!
                Temperatur Innen: 24.00 °C
                Temperatur Aussen: 2.72 °C
                Taupunkt: 2.50 °C
                Chill-Faktor: 2.72 °C
                Luftfeuchte Innen: 41 %
                Luftfeuchte Aussen: 99 %
                Windgeschwindkeit: 0 km/h
                max. Windgeschwindkeit: 0 km/h
                Windrichtung: 270 °
                Luftdruck absolut: 969.4218 hPa
                Luftdruck relativ: 1029.9366 hPa
                Regen aktuell: 0 mm
                Regen Tag: 0 mm
                Regen Woche: 0 mm
                Regen Monat: 0 mm
                Sonnenstrahlung: 50.28 W/m^2
                UV-Index: 0
                Listening on [0.0.0.0] (family 2, port 80)

                Hast du noch einen weiterführenden Tipp für mich, wie ich die gesammelten Daten mit dem Simple-Adapter einbinden kann?

                SBorgS 1 Reply Last reply
                0
                • LatziL Latzi

                  @SBorg schaut mit den Daten schon mal gut aus und es ist so simpel, dass den Code sogar ich verstehe 👍

                  Listening on [0.0.0.0] (family 2, port 80)
                  Connection from 10.0.0.35 21364 received!
                  Temperatur Innen: 24.00 °C
                  Temperatur Aussen: 2.72 °C
                  Taupunkt: 2.50 °C
                  Chill-Faktor: 2.72 °C
                  Luftfeuchte Innen: 41 %
                  Luftfeuchte Aussen: 99 %
                  Windgeschwindkeit: 0 km/h
                  max. Windgeschwindkeit: 0 km/h
                  Windrichtung: 270 °
                  Luftdruck absolut: 969.4218 hPa
                  Luftdruck relativ: 1029.9366 hPa
                  Regen aktuell: 0 mm
                  Regen Tag: 0 mm
                  Regen Woche: 0 mm
                  Regen Monat: 0 mm
                  Sonnenstrahlung: 50.28 W/m^2
                  UV-Index: 0
                  Listening on [0.0.0.0] (family 2, port 80)

                  Hast du noch einen weiterführenden Tipp für mich, wie ich die gesammelten Daten mit dem Simple-Adapter einbinden kann?

                  SBorgS Offline
                  SBorgS Offline
                  SBorg
                  Forum Testing Most Active
                  wrote on last edited by SBorg
                  #12

                  @Latzi Sag ja "easy going" und simpel. Wahrscheinlich hast du #7 + #8 nur dupliziert und "-f3" immer um eins hochgezählt. Hätte ich der Einfachheit halber auch gemacht. Normalerweise würde mein ein Array anlegen, eine Funktion erstellen, aber so ist es einfach einfacher 🙂

                  Adapter: Jepp, vergesse noch, dass der ab JS 2.0 nun Restful heißt 😉
                  Ich arbeite in meinen Scripten gerne mit Variablen, so muss ich nur bei Bedarf am Anfang des Scripts diese ändern, und nicht den ganzen Quellcode durchsuchen/ändern muss.

                  #!/bin/bash   
                  
                  ###Settings
                   debug=true            #[true/false]
                   IPP=192.168.x.xx:8082 #ioBroker-IP:Port
                   PRE_DP=javascript.0.Wetterstation #Datenpunkt
                   DP_TEMP_INNEN=${PRE_DP}.Innentemperatur
                   DP_TEMP_AUSSEN=${PRE_DP}.Aussentemperatur
                  
                  
                  while true
                  do
                  
                    DATA=`nc -lv 80|grep GET`
                    
                     TEMP_INNEN=$(echo ${DATA}|cut -d'&' -f3 | cut -d"=" -f2)
                     TEMP_INNEN=`echo "scale=2;(${TEMP_INNEN}-32)*5/9" | bc -l`
                     TEMP_AUSSEN=$(echo ${DATA}|cut -d'&' -f4 | cut -d"=" -f2)
                     TEMP_AUSSEN=`echo "scale=2;(${TEMP_AUSSEN}-32)*5/9" | bc -l`
                  
                   #Daten an ioB schicken
                      curl --data "${DP_TEMP_INNEN}=$TEMP_INNEN&${DP_TEMP_AUSSEN}=$TEMP_AUSSEN&prettyPrint" http://${IPP}/setBulk
                  
                   if [ $debug == "true" ]; then
                     echo Temperatur Innen: $TEMP_INNEN °C
                     echo Temperatur Aussen: $TEMP_AUSSEN °C
                   fi
                  done
                  

                  Ich weiß gerade nicht, ob man außerhalb des Javascript speichern kann, deswegen hier "javascript.0..." als Datenverzeichnis. MyOwnData wäre IMHO besser. Die Datenpunkte müssen vorher per Hand angelegt werden. ich habe ein allgemeines Javascript, dass nur alle anzulegenden Datenpunkte erzeugt. Im Falle des Falles starte ich das einmalig, schon sind alle DPs wieder da 😉

                  LG SBorg ( SBorg auf GitHub)
                  Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

                  LatziL 1 Reply Last reply
                  1
                  • SBorgS SBorg

                    @Latzi Sag ja "easy going" und simpel. Wahrscheinlich hast du #7 + #8 nur dupliziert und "-f3" immer um eins hochgezählt. Hätte ich der Einfachheit halber auch gemacht. Normalerweise würde mein ein Array anlegen, eine Funktion erstellen, aber so ist es einfach einfacher 🙂

                    Adapter: Jepp, vergesse noch, dass der ab JS 2.0 nun Restful heißt 😉
                    Ich arbeite in meinen Scripten gerne mit Variablen, so muss ich nur bei Bedarf am Anfang des Scripts diese ändern, und nicht den ganzen Quellcode durchsuchen/ändern muss.

                    #!/bin/bash   
                    
                    ###Settings
                     debug=true            #[true/false]
                     IPP=192.168.x.xx:8082 #ioBroker-IP:Port
                     PRE_DP=javascript.0.Wetterstation #Datenpunkt
                     DP_TEMP_INNEN=${PRE_DP}.Innentemperatur
                     DP_TEMP_AUSSEN=${PRE_DP}.Aussentemperatur
                    
                    
                    while true
                    do
                    
                      DATA=`nc -lv 80|grep GET`
                      
                       TEMP_INNEN=$(echo ${DATA}|cut -d'&' -f3 | cut -d"=" -f2)
                       TEMP_INNEN=`echo "scale=2;(${TEMP_INNEN}-32)*5/9" | bc -l`
                       TEMP_AUSSEN=$(echo ${DATA}|cut -d'&' -f4 | cut -d"=" -f2)
                       TEMP_AUSSEN=`echo "scale=2;(${TEMP_AUSSEN}-32)*5/9" | bc -l`
                    
                     #Daten an ioB schicken
                        curl --data "${DP_TEMP_INNEN}=$TEMP_INNEN&${DP_TEMP_AUSSEN}=$TEMP_AUSSEN&prettyPrint" http://${IPP}/setBulk
                    
                     if [ $debug == "true" ]; then
                       echo Temperatur Innen: $TEMP_INNEN °C
                       echo Temperatur Aussen: $TEMP_AUSSEN °C
                     fi
                    done
                    

                    Ich weiß gerade nicht, ob man außerhalb des Javascript speichern kann, deswegen hier "javascript.0..." als Datenverzeichnis. MyOwnData wäre IMHO besser. Die Datenpunkte müssen vorher per Hand angelegt werden. ich habe ein allgemeines Javascript, dass nur alle anzulegenden Datenpunkte erzeugt. Im Falle des Falles starte ich das einmalig, schon sind alle DPs wieder da 😉

                    LatziL Online
                    LatziL Online
                    Latzi
                    wrote on last edited by
                    #13

                    @SBorg vielen Dank läuft perfekt nachdem ich den Port auf 8087 geändert habe (8082 ist bei mir die vis). Die Datenpunkte per Hand anlegen war etwas mühsam, wie kann ich die DP´s per Javascript anlegen - klingt sehr vernünftig? Kann ich den RAW-Code der einzelnen DP´s dazu verwenden oder gibt´s ein kleines Beispiel? Es ist mein erstes Mal mit Javascript, sorry für die dumme Frage. Und noch eine dumme Frage, damit das Script zur Abfrage der Wetterstationsdaten automatisch nach jedem Start des Pi läuft reicht es wenn ich´s in /etc/rc.local eintrage?

                    SBorgS 1 Reply Last reply
                    0
                    • LatziL Latzi

                      @SBorg vielen Dank läuft perfekt nachdem ich den Port auf 8087 geändert habe (8082 ist bei mir die vis). Die Datenpunkte per Hand anlegen war etwas mühsam, wie kann ich die DP´s per Javascript anlegen - klingt sehr vernünftig? Kann ich den RAW-Code der einzelnen DP´s dazu verwenden oder gibt´s ein kleines Beispiel? Es ist mein erstes Mal mit Javascript, sorry für die dumme Frage. Und noch eine dumme Frage, damit das Script zur Abfrage der Wetterstationsdaten automatisch nach jedem Start des Pi läuft reicht es wenn ich´s in /etc/rc.local eintrage?

                      SBorgS Offline
                      SBorgS Offline
                      SBorg
                      Forum Testing Most Active
                      wrote on last edited by
                      #14

                      @Latzi 8087 ist auch richtig 😉
                      Ich habe das ganze Script ungetestet direkt hier geschrieben (hab ja keine Wetterstation).
                      ...und es gibt keine dummen Fragen, nur dumme Antworten...
                      Nach rc.local würde ich es nicht legen, denn dann hängt dein PI fest. Er führt das Skript aus, wird aber aufgrund der Endlosschleife im Skript nie damit fertig und führt auch keine weiteren Schritte aus.

                      crontab -e
                      

                      dort einfach einfügen (wichtig: die letzte Zeile muss eine Leerzeile sein!):

                      @reboot /Pfad/name_des.skripts.sh &
                      

                      Durch das abschließende & läuft die Verarbeitung weiter, egal ob das Skript noch läuft oder nicht.

                      Einfach ein leeres JS anlegen, Ort und Name sind egal, Inhalt nach folgendem Muster:

                      createState('javascript.0.Wetterstation.Innentemperatur', '0', { name: "Temperatur im Haus",
                      								 type: "number",
                      								 role: "state",
                      								 unit: "°C",
                      								 read: true,
                      								 write: true
                      								});
                      

                      "Unit"," read" und "write" müssen nicht sein. Pauschal kannst du die möglichen Werte auch bei RAW des DPs sehen (wenn du sie grafisch mal angelegt hast). Wenn du das Skript dann startest werden die DPs angelegt. Danach kannst du es wieder stoppen. @paul53 hat auch einen Codeschnipsel gepostet mit dem es möglich ist DPs auch außerhalb von javascript.x anzulegen. Man kann sich natürlich auch die ganzen DPs als JSON exportieren 🙂

                      LG SBorg ( SBorg auf GitHub)
                      Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

                      1 Reply Last reply
                      0
                      • LatziL Online
                        LatziL Online
                        Latzi
                        wrote on last edited by
                        #15

                        @SBorg 👍 👍 👍 toller Support, alles läuft bestens - herzlichen Dank!!!

                        1 Reply Last reply
                        0
                        • LatziL Latzi

                          @SBorg sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

                          nc -lv Port

                          @SBorg das ist ja Weltklasse!!! 🙌 💪

                          Ich habe in den Einstellungen der Wetterstation die IP des Pi eingetragen und eine Station-ID sowie ein Passwort festgelegt, den Port hätte ich ändern können, hab ich einstweilen auf 80 belassen (Vorbelegung) auch das Sendeintervall ist einstellbar (derzeit 60 sek) und das geschah:

                          Eingabe:

                          sudo nc -lv 80
                          

                          Ergebnis:

                          Listening on [0.0.0.0] (family 2, port 80)
                          Connection from 10.0.0.35 1840 received!
                          GET /weatherstation/updateweatherstation.php?ID=ITRAGW1&PASSWORD=LATZI&indoortempf=75.2&tempf=40.8&dewptf=39.0&windchillf=40.8&indoorhumidity=42&humidity=94&windspeedmph=2.9&windgustmph=4.5&winddir=236&absbaromin=28.308&baromin=30.095&rainin=0.000&dailyrainin=0.012&weeklyrainin=0.201&monthlyrainin=1.673&solarradiation=0.00&UV=0&dateutc=2019-12-25%2005:11:31&softwaretype=EasyWeatherV1.4.4&action=updateraw&realtime=1&rtfreq=5 HTTP/1.0
                          Host: 10.0.0.210
                          Accept:*/*
                          Connection: Close
                          
                          

                          Scheint als werden die gesamten Daten übertragen, die Einheiten sind noch nicht umgerechnet, das ist jedoch das geringste Problem.

                          Jetzt wird´s so richtig interessant für mich, stellt sich für mich die Frage, wie bekomme ich die empfangene Datenstruktur in den ioBroker????

                          B Offline
                          B Offline
                          Berchemer
                          wrote on last edited by
                          #16

                          @Latzi sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

                          @SBorg das ist ja Weltklasse!!! 🙌 💪

                          Ich habe in den Einstellungen der Wetterstation die IP des Pi eingetragen und eine Station-ID sowie ein Passwort festgelegt, den Port hätte ich ändern können, hab ich einstweilen auf 80 belassen (Vorbelegung) auch das Sendeintervall ist einstellbar (derzeit 60 sek) und das geschah:

                          Eingabe:

                          sudo nc -lv 80
                          

                          Ergebnis:

                          Listening on [0.0.0.0] (family 2, port 80)
                          Connection from 10.0.0.35 1840 received!
                          GET /weatherstation/updateweatherstation.php?ID=ITRAGW1&PASSWORD=LATZI&indoortempf=75.2&tempf=40.8&dewptf=39.0&windchillf=40.8&indoorhumidity=42&humidity=94&windspeedmph=2.9&windgustmph=4.5&winddir=236&absbaromin=28.308&baromin=30.095&rainin=0.000&dailyrainin=0.012&weeklyrainin=0.201&monthlyrainin=1.673&solarradiation=0.00&UV=0&dateutc=2019-12-25%2005:11:31&softwaretype=EasyWeatherV1.4.4&action=updateraw&realtime=1&rtfreq=5 HTTP/1.0
                          Host: 10.0.0.210
                          Accept:*/*
                          Connection: Close
                          
                          

                          Hallo Latzi und SBorg...

                          Ich besitze eine WS3500 und kann über die APP (WSView auf Android) neben der Übersendung an WU auch eine customized-IP einstellen.
                          In der Maske der APP habe ich folgende Daten eingetragen und doch noch einige Fragen:

                          Als Protokolltyp habe ich es bei WU gelassen.
                          Als ServerIP habe ich die IP meines MINT-Servers mit vorangestelltem "http://" eingetragen.
                          Als Path habe ich es wie bei dir bei "/weatherstation/updateweatherstation.php?" gelassen.

                          Die StationID, welche du eingetragen hast... Ist das die gleiche wie bei WU oder eine selber ausgedachte? Ich habe es hier sowohl mit Leerlassen, als auch mit der WU-ID versucht.
                          Und Station-Key dürfte dann das Passwort sein, richtig? Auch hier habe ich das Feld sowohl mal leer gelassen, als auch mal mit einem Testpw versucht.

                          Als Port habe ich es mit 8087 oder 8097 oder auch 80 versucht.
                          Upload-Intervall habe ich testweise auf 20 sek runtergesetzt.

                          Alles schön gespeichert und auf dem Server ebenfalls "sudo nc -lv PORTNUMMER" eingetragen. Warten, warten, warten, aber es kommt nichts rein.

                          [nc] gibt mir z.B. aus: "Listening on [0.0.0.0] (family 0, port 8097)"

                          Nur Nada an ankommenden Daten???

                          Kann es sein, dass ich einen Denkfehler mache oder könnte mir in der Standardinstallation von Mint 19.2 etwas fehlen, was in Raspbian auf einem Raspberry vielleicht standardmäßig eingebunden wäre?

                          [Hier zur Sicherheit beigefügt Foto der Maske in der APP]
                          IMG_20191227_122133_bearbeitet.jpg

                          SBorgS LatziL 2 Replies Last reply
                          0
                          • B Berchemer

                            @Latzi sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

                            @SBorg das ist ja Weltklasse!!! 🙌 💪

                            Ich habe in den Einstellungen der Wetterstation die IP des Pi eingetragen und eine Station-ID sowie ein Passwort festgelegt, den Port hätte ich ändern können, hab ich einstweilen auf 80 belassen (Vorbelegung) auch das Sendeintervall ist einstellbar (derzeit 60 sek) und das geschah:

                            Eingabe:

                            sudo nc -lv 80
                            

                            Ergebnis:

                            Listening on [0.0.0.0] (family 2, port 80)
                            Connection from 10.0.0.35 1840 received!
                            GET /weatherstation/updateweatherstation.php?ID=ITRAGW1&PASSWORD=LATZI&indoortempf=75.2&tempf=40.8&dewptf=39.0&windchillf=40.8&indoorhumidity=42&humidity=94&windspeedmph=2.9&windgustmph=4.5&winddir=236&absbaromin=28.308&baromin=30.095&rainin=0.000&dailyrainin=0.012&weeklyrainin=0.201&monthlyrainin=1.673&solarradiation=0.00&UV=0&dateutc=2019-12-25%2005:11:31&softwaretype=EasyWeatherV1.4.4&action=updateraw&realtime=1&rtfreq=5 HTTP/1.0
                            Host: 10.0.0.210
                            Accept:*/*
                            Connection: Close
                            
                            

                            Hallo Latzi und SBorg...

                            Ich besitze eine WS3500 und kann über die APP (WSView auf Android) neben der Übersendung an WU auch eine customized-IP einstellen.
                            In der Maske der APP habe ich folgende Daten eingetragen und doch noch einige Fragen:

                            Als Protokolltyp habe ich es bei WU gelassen.
                            Als ServerIP habe ich die IP meines MINT-Servers mit vorangestelltem "http://" eingetragen.
                            Als Path habe ich es wie bei dir bei "/weatherstation/updateweatherstation.php?" gelassen.

                            Die StationID, welche du eingetragen hast... Ist das die gleiche wie bei WU oder eine selber ausgedachte? Ich habe es hier sowohl mit Leerlassen, als auch mit der WU-ID versucht.
                            Und Station-Key dürfte dann das Passwort sein, richtig? Auch hier habe ich das Feld sowohl mal leer gelassen, als auch mal mit einem Testpw versucht.

                            Als Port habe ich es mit 8087 oder 8097 oder auch 80 versucht.
                            Upload-Intervall habe ich testweise auf 20 sek runtergesetzt.

                            Alles schön gespeichert und auf dem Server ebenfalls "sudo nc -lv PORTNUMMER" eingetragen. Warten, warten, warten, aber es kommt nichts rein.

                            [nc] gibt mir z.B. aus: "Listening on [0.0.0.0] (family 0, port 8097)"

                            Nur Nada an ankommenden Daten???

                            Kann es sein, dass ich einen Denkfehler mache oder könnte mir in der Standardinstallation von Mint 19.2 etwas fehlen, was in Raspbian auf einem Raspberry vielleicht standardmäßig eingebunden wäre?

                            [Hier zur Sicherheit beigefügt Foto der Maske in der APP]
                            IMG_20191227_122133_bearbeitet.jpg

                            SBorgS Offline
                            SBorgS Offline
                            SBorg
                            Forum Testing Most Active
                            wrote on last edited by
                            #17

                            Hi,
                            ich kann da auch nur raten (von wegen hab keine Station 😉 )
                            @Berchemer sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

                            Als ServerIP habe ich die IP meines MINT-Servers mit vorangestelltem "http://" eingetragen.

                            Zumindest würde ich als ServerIP implizieren, dass er hier xxx.xxx.xxx.xxx erwartet. http://xxx.xxx.xxx.xxx ist eine URL, dann sollte da auch ServerURL stehen wenn er dies erwartet (aber man weiß ja nie...).
                            StationID ist IMO frei wählbar, nur dass man bei mehreren (oder von Nachbarn) diese unterscheiden kann. Wird hier aber, genauso wie das Passwort, später nicht ausgewertet/benötigt. Die Station sendet die Daten ja "freiwillig" (könnte man im bash-Skript aber auch evaluieren, nicht dass einer mal falsche Messdaten schickt 😉 ).
                            Der Port ist nur der auf dem gesendet wird. Er muss auf deinem Mint frei sein und netcat (nc) muss dann auf diesem lauschen.

                            Pauschal könnten auf dem Mint auch Ports geblockt sein, oder dein WLAN-AP/-Router reicht sie nicht weiter.

                            LG SBorg ( SBorg auf GitHub)
                            Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

                            LatziL 1 Reply Last reply
                            1
                            • B Berchemer

                              @Latzi sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

                              @SBorg das ist ja Weltklasse!!! 🙌 💪

                              Ich habe in den Einstellungen der Wetterstation die IP des Pi eingetragen und eine Station-ID sowie ein Passwort festgelegt, den Port hätte ich ändern können, hab ich einstweilen auf 80 belassen (Vorbelegung) auch das Sendeintervall ist einstellbar (derzeit 60 sek) und das geschah:

                              Eingabe:

                              sudo nc -lv 80
                              

                              Ergebnis:

                              Listening on [0.0.0.0] (family 2, port 80)
                              Connection from 10.0.0.35 1840 received!
                              GET /weatherstation/updateweatherstation.php?ID=ITRAGW1&PASSWORD=LATZI&indoortempf=75.2&tempf=40.8&dewptf=39.0&windchillf=40.8&indoorhumidity=42&humidity=94&windspeedmph=2.9&windgustmph=4.5&winddir=236&absbaromin=28.308&baromin=30.095&rainin=0.000&dailyrainin=0.012&weeklyrainin=0.201&monthlyrainin=1.673&solarradiation=0.00&UV=0&dateutc=2019-12-25%2005:11:31&softwaretype=EasyWeatherV1.4.4&action=updateraw&realtime=1&rtfreq=5 HTTP/1.0
                              Host: 10.0.0.210
                              Accept:*/*
                              Connection: Close
                              
                              

                              Hallo Latzi und SBorg...

                              Ich besitze eine WS3500 und kann über die APP (WSView auf Android) neben der Übersendung an WU auch eine customized-IP einstellen.
                              In der Maske der APP habe ich folgende Daten eingetragen und doch noch einige Fragen:

                              Als Protokolltyp habe ich es bei WU gelassen.
                              Als ServerIP habe ich die IP meines MINT-Servers mit vorangestelltem "http://" eingetragen.
                              Als Path habe ich es wie bei dir bei "/weatherstation/updateweatherstation.php?" gelassen.

                              Die StationID, welche du eingetragen hast... Ist das die gleiche wie bei WU oder eine selber ausgedachte? Ich habe es hier sowohl mit Leerlassen, als auch mit der WU-ID versucht.
                              Und Station-Key dürfte dann das Passwort sein, richtig? Auch hier habe ich das Feld sowohl mal leer gelassen, als auch mal mit einem Testpw versucht.

                              Als Port habe ich es mit 8087 oder 8097 oder auch 80 versucht.
                              Upload-Intervall habe ich testweise auf 20 sek runtergesetzt.

                              Alles schön gespeichert und auf dem Server ebenfalls "sudo nc -lv PORTNUMMER" eingetragen. Warten, warten, warten, aber es kommt nichts rein.

                              [nc] gibt mir z.B. aus: "Listening on [0.0.0.0] (family 0, port 8097)"

                              Nur Nada an ankommenden Daten???

                              Kann es sein, dass ich einen Denkfehler mache oder könnte mir in der Standardinstallation von Mint 19.2 etwas fehlen, was in Raspbian auf einem Raspberry vielleicht standardmäßig eingebunden wäre?

                              [Hier zur Sicherheit beigefügt Foto der Maske in der APP]
                              IMG_20191227_122133_bearbeitet.jpg

                              LatziL Online
                              LatziL Online
                              Latzi
                              wrote on last edited by
                              #18

                              @Berchemer hier meine Einstellungen:
                              5b4b5017-8aa8-4437-8c80-a7fd0e578d73-grafik.png
                              Lasse das http weg und wähle einen anderen Port, da 8087 vom Simple-Adapter belegt sein wird.

                              Path wie vorgegeben, StationID und Key kannst leer lassen, ich hab´s belegt - muss nicht sein.

                              Versuchs mal, wenns klappt kann ich das Script reinstellen, ist zwar sicher verbesserungswürdig aber es läuft.

                              SBorgS 1 Reply Last reply
                              1
                              • SBorgS SBorg

                                Hi,
                                ich kann da auch nur raten (von wegen hab keine Station 😉 )
                                @Berchemer sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

                                Als ServerIP habe ich die IP meines MINT-Servers mit vorangestelltem "http://" eingetragen.

                                Zumindest würde ich als ServerIP implizieren, dass er hier xxx.xxx.xxx.xxx erwartet. http://xxx.xxx.xxx.xxx ist eine URL, dann sollte da auch ServerURL stehen wenn er dies erwartet (aber man weiß ja nie...).
                                StationID ist IMO frei wählbar, nur dass man bei mehreren (oder von Nachbarn) diese unterscheiden kann. Wird hier aber, genauso wie das Passwort, später nicht ausgewertet/benötigt. Die Station sendet die Daten ja "freiwillig" (könnte man im bash-Skript aber auch evaluieren, nicht dass einer mal falsche Messdaten schickt 😉 ).
                                Der Port ist nur der auf dem gesendet wird. Er muss auf deinem Mint frei sein und netcat (nc) muss dann auf diesem lauschen.

                                Pauschal könnten auf dem Mint auch Ports geblockt sein, oder dein WLAN-AP/-Router reicht sie nicht weiter.

                                LatziL Online
                                LatziL Online
                                Latzi
                                wrote on last edited by
                                #19

                                @SBorg sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

                                Zumindest würde ich als ServerIP implizieren, dass er hier xxx.xxx.xxx.xxx erwartet. http://xxx.xxx.xxx.xxx ist eine URL

                                Absolut richtig 👍

                                1 Reply Last reply
                                1
                                • LatziL Latzi

                                  @Berchemer hier meine Einstellungen:
                                  5b4b5017-8aa8-4437-8c80-a7fd0e578d73-grafik.png
                                  Lasse das http weg und wähle einen anderen Port, da 8087 vom Simple-Adapter belegt sein wird.

                                  Path wie vorgegeben, StationID und Key kannst leer lassen, ich hab´s belegt - muss nicht sein.

                                  Versuchs mal, wenns klappt kann ich das Script reinstellen, ist zwar sicher verbesserungswürdig aber es läuft.

                                  SBorgS Offline
                                  SBorgS Offline
                                  SBorg
                                  Forum Testing Most Active
                                  wrote on last edited by
                                  #20

                                  @Latzi sagte in WLAN-Wetterstation in ioBroker direkt einbinden:

                                  Versuchs mal, wenns klappt kann ich das Script reinstellen, ist zwar sicher verbesserungswürdig aber es läuft.

                                  Schöner wäre natürlich ein Adapter, aber da habe ich schon x-mal angefangen, und genauso oft wieder aufgehört 😉
                                  Man könnte es natürlich auch optimieren, wie bspw. eine Funktion nutzen, um die wiederkehrende Konvertierung von °F nach °C durchzurechnen und, und, und...

                                  LG SBorg ( SBorg auf GitHub)
                                  Projekte: Lebensmittelwarnung.de | WLAN-Wetterstation | PimpMyStation

                                  1 Reply Last reply
                                  0
                                  • B Offline
                                    B Offline
                                    Berchemer
                                    wrote on last edited by Berchemer
                                    #21

                                    Habe mal auf Port 8096 geändert und das http:// weggelassen und habe tatsächlich Daten erhalten.
                                    Danke 👍 👍 👏 👏 😀

                                    Jetzt muss ich mal den Weg von Latzi nachverfolgen, um zu sehen, was ich noch umsetzen muss 😀

                                    LatziL 1 Reply Last reply
                                    0
                                    • B Berchemer

                                      Habe mal auf Port 8096 geändert und das http:// weggelassen und habe tatsächlich Daten erhalten.
                                      Danke 👍 👍 👏 👏 😀

                                      Jetzt muss ich mal den Weg von Latzi nachverfolgen, um zu sehen, was ich noch umsetzen muss 😀

                                      LatziL Online
                                      LatziL Online
                                      Latzi
                                      wrote on last edited by
                                      #22

                                      @Berchemer

                                      hier mal das Script:

                                      #!/bin/bash
                                      
                                      ###Settings
                                      
                                      debug=true                        #[true/false]
                                      
                                      IPP=10.0.0.210:8087               #ioBroker-IP:Port
                                      
                                      PRE_DP=javascript.0.Wetterstation #Datenpunkt
                                      DP_TEMP_INNEN=${PRE_DP}.Innentemperatur
                                      DP_TEMP_AUSSEN=${PRE_DP}.Aussentemperatur
                                      DP_TAUPUNKT=${PRE_DP}.Taupunkt
                                      DP_CHILL=${PRE_DP}.Chillfaktor
                                      DP_FEUCHTE_INNEN=${PRE_DP}.Innenfeuchtigkeit
                                      DP_FEUCHTE_AUSSEN=${PRE_DP}.Aussenfeuchtigkeit
                                      DP_WIND=${PRE_DP}.Wind
                                      DP_WIND_MAX=${PRE_DP}.Wind_max
                                      DP_WIND_DIR=${PRE_DP}.Windrichtung
                                      DP_DRUCK_ABS=${PRE_DP}.Druck_absolut
                                      DP_DRUCK_REL=${PRE_DP}.Druck_relativ
                                      DP_REGEN_AKT=${PRE_DP}.Regen_aktuell
                                      DP_REGEN_TAG=${PRE_DP}.Regen_Tag
                                      DP_REGEN_WOCHE=${PRE_DP}.Regen_Woche
                                      DP_REGEN_MONAT=${PRE_DP}.Regen_Monat
                                      DP_SONNE=${PRE_DP}.Sonnenstrahlung
                                      DP_UV_INDEX=${PRE_DP}.UV_Index
                                      DP_DATUM=${PRE_DP}.Datum
                                      DP_ZEIT=${PRE_DP}.Zeit
                                      
                                      # Endlosschleife
                                       
                                      while true
                                      do
                                        #Datenzeile von Wetterstation abholen und Zeile mit GET am Anfang rausfiltern
                                        DATA=`nc -lv 80|grep GET`
                                      
                                        #DATA zerlegen
                                        #Innentemperatur:
                                         TEMP_INNEN=$(echo ${DATA}|cut -d'&' -f3 | cut -d"=" -f2)
                                         TEMP_INNEN=`echo "scale=2;(${TEMP_INNEN}-32)*5/9"|bc -l`
                                        #Aussentemperatur:
                                         TEMP_AUSSEN=$(echo ${DATA}|cut -d'&' -f4 | cut -d"=" -f2)
                                         TEMP_AUSSEN=`echo "scale=2;(${TEMP_AUSSEN}-32)*5/9"|bc -l`
                                        #Taupunkt:
                                         TAUPUNKT=$(echo ${DATA}|cut -d'&' -f5 | cut -d"=" -f2)
                                         TAUPUNKT=`echo "scale=2;(${TAUPUNKT}-32)*5/9"|bc -l`
                                        #Chill-Faktor:
                                         CHILL=$(echo ${DATA}|cut -d'&' -f6 | cut -d"=" -f2)
                                         CHILL=`echo "scale=2;(${CHILL}-32)*5/9"|bc -l`
                                        #Innenluftfeuchte:
                                         FEUCHTE_INNEN=$(echo ${DATA}|cut -d'&' -f7 | cut -d"=" -f2)
                                        #Aussenluftfeuchte:
                                         FEUCHTE_AUSSEN=$(echo ${DATA}|cut -d'&' -f8 | cut -d"=" -f2)
                                        #Windgeschwindigkeit:
                                         WIND=$(echo ${DATA}|cut -d'&' -f9 | cut -d"=" -f2)
                                         WIND=`echo "scale=2;${WIND}*16094/10000"|bc -l`
                                        #Windgeschwindigkeit max:
                                         WIND_MAX=$(echo ${DATA}|cut -d'&' -f10 | cut -d"=" -f2)
                                         WIND_MAX=`echo "scale=2;${WIND_MAX}*16094/10000"|bc -l`
                                        #Windrichtung:
                                         WIND_DIR=$(echo ${DATA}|cut -d'&' -f11 | cut -d"=" -f2)
                                        #Luftdruck absolut:
                                         DRUCK_ABS=$(echo ${DATA}|cut -d'&' -f12 | cut -d"=" -f2)
                                         DRUCK_ABS=`echo "scale=2;${DRUCK_ABS}*33864/1000"|bc -l`
                                        #Luftdruck relativ:
                                         DRUCK_REL=$(echo ${DATA}|cut -d'&' -f13 | cut -d"=" -f2)
                                         DRUCK_REL=`echo "scale=2;${DRUCK_REL}*33864/1000"|bc -l`
                                        #Regen aktuell:
                                         REGEN_AKT=$(echo ${DATA}|cut -d'&' -f14 | cut -d"=" -f2)
                                         REGEN_AKT=`echo "scale=1;${REGEN_AKT}*254/10"|bc -l`
                                        #Regen Tag:
                                         REGEN_TAG=$(echo ${DATA}|cut -d'&' -f15 | cut -d"=" -f2)
                                         REGEN_TAG=`echo "scale=1;${REGEN_TAG}*254/10"|bc -l`
                                        #Regen Woche:
                                         REGEN_WOCHE=$(echo ${DATA}|cut -d'&' -f16 | cut -d"=" -f2)
                                         REGEN_WOCHE=`echo "scale=1;${REGEN_WOCHE}*254/10"|bc -l`
                                        #Regen Monat:
                                         REGEN_MONAT=$(echo ${DATA}|cut -d'&' -f17 | cut -d"=" -f2)
                                         REGEN_MONAT=`echo "scale=1;${REGEN_MONAT}*254/10"|bc -l`
                                        #Sonnenstrahlung:
                                         SONNE=$(echo ${DATA}|cut -d'&' -f18 | cut -d"=" -f2)
                                        #UV-Index:
                                         UV_INDEX=$(echo ${DATA}|cut -d'&' -f19 | cut -d"=" -f2)
                                      
                                        #Datum und Zeit abfragen
                                         DAT_ZEIT=`timedatectl |grep Local`
                                         DATUM=$(echo ${DAT_ZEIT}|cut -d' ' -f4)
                                         UHRZEIT=$(echo ${DAT_ZEIT}|cut -d' ' -f5)
                                      
                                      #Daten an ioB schicken
                                      
                                         curl --data "${DP_TEMP_INNEN}=$TEMP_INNEN&${DP_TEMP_AUSSEN}=$TEMP_AUSSEN&${DP_TAUPUNKT}=$TAUPUNKT&${DP_CHILL}=$CHILL&${DP_FEUCHTE_INNEN}=$FEUCHTE_INNEN&${DP_FEUCHTE_AUSSEN}=$FEUCHTE_AUSSEN&${DP_WIND}=$WIND&${DP_WIND_MAX}=$WIND_MAX&${DP_WIND_DIR}=$WIND_DIR&${DP_DRUCK_ABS}=$DRUCK_ABS&${DP_DRUCK_REL}=$DRUCK_REL&${DP_REGEN_AKT}=$REGEN_AKT&${DP_REGEN_TAG}=$REGEN_TAG&${DP_REGEN_WOCHE}=$REGEN_WOCHE&${DP_REGEN_MONAT}=$REGEN_MONAT&${DP_SONNE}=$SONNE&${DP_UV_INDEX}=$UV_INDEX&${DP_DATUM}=$DATUM&${DP_ZEIT}=$UHRZEIT&prettyPrint" http://${IPP}/setBulk
                                      
                                      if [ $debug == "true" ]; then
                                         # Datenfelder ausgeben
                                         echo Temperatur Innen: $TEMP_INNEN °C
                                         echo Temperatur Aussen: $TEMP_AUSSEN °C
                                         echo Taupunkt: $TAUPUNKT °C
                                         echo Chill-Faktor: $CHILL °C
                                         echo Luftfeuchte Innen: $FEUCHTE_INNEN %
                                         echo Luftfeuchte Aussen: $FEUCHTE_AUSSEN %
                                         echo Windgeschwindkeit: $WIND km/h
                                         echo max. Windgeschwindkeit: $WIND_MAX km/h
                                         echo Windrichtung: $WIND_DIR °
                                         echo Luftdruck absolut: $DRUCK_ABS hPa
                                         echo Luftdruck relativ: $DRUCK_REL hPa
                                         echo Regen aktuell: $REGEN_AKT mm
                                         echo Regen Tag: $REGEN_TAG mm
                                         echo Regen Woche: $REGEN_WOCHE mm
                                         echo Regen Monat: $REGEN_MONAT mm
                                         echo Sonnenstrahlung: $SONNE W/m^2
                                         echo UV-Index: $UV_INDEX
                                         echo Datum: $DATUM Zeit: $UHRZEIT
                                      fi
                                      
                                      done
                                      
                                      

                                      Zusätzlich sind die Datenpunkte anzulegen ( ich hab´s unter javascript.0.Wetterstation) und der Adapter (Simple RESTFul) zu installieren, sowie das Script im "Autostart" (crontab -e) zu platzieren (@SBorg hat das sehr schön beschrieben) - das war´s auch schon!

                                      Bei der Umrechnung der Windgeschwindigkeiten bin ich mir noch nicht sicher, leider bläst gerade kein Wind 🙂

                                      B 1 Reply Last reply
                                      0
                                      • LatziL Latzi

                                        @Berchemer

                                        hier mal das Script:

                                        #!/bin/bash
                                        
                                        ###Settings
                                        
                                        debug=true                        #[true/false]
                                        
                                        IPP=10.0.0.210:8087               #ioBroker-IP:Port
                                        
                                        PRE_DP=javascript.0.Wetterstation #Datenpunkt
                                        DP_TEMP_INNEN=${PRE_DP}.Innentemperatur
                                        DP_TEMP_AUSSEN=${PRE_DP}.Aussentemperatur
                                        DP_TAUPUNKT=${PRE_DP}.Taupunkt
                                        DP_CHILL=${PRE_DP}.Chillfaktor
                                        DP_FEUCHTE_INNEN=${PRE_DP}.Innenfeuchtigkeit
                                        DP_FEUCHTE_AUSSEN=${PRE_DP}.Aussenfeuchtigkeit
                                        DP_WIND=${PRE_DP}.Wind
                                        DP_WIND_MAX=${PRE_DP}.Wind_max
                                        DP_WIND_DIR=${PRE_DP}.Windrichtung
                                        DP_DRUCK_ABS=${PRE_DP}.Druck_absolut
                                        DP_DRUCK_REL=${PRE_DP}.Druck_relativ
                                        DP_REGEN_AKT=${PRE_DP}.Regen_aktuell
                                        DP_REGEN_TAG=${PRE_DP}.Regen_Tag
                                        DP_REGEN_WOCHE=${PRE_DP}.Regen_Woche
                                        DP_REGEN_MONAT=${PRE_DP}.Regen_Monat
                                        DP_SONNE=${PRE_DP}.Sonnenstrahlung
                                        DP_UV_INDEX=${PRE_DP}.UV_Index
                                        DP_DATUM=${PRE_DP}.Datum
                                        DP_ZEIT=${PRE_DP}.Zeit
                                        
                                        # Endlosschleife
                                         
                                        while true
                                        do
                                          #Datenzeile von Wetterstation abholen und Zeile mit GET am Anfang rausfiltern
                                          DATA=`nc -lv 80|grep GET`
                                        
                                          #DATA zerlegen
                                          #Innentemperatur:
                                           TEMP_INNEN=$(echo ${DATA}|cut -d'&' -f3 | cut -d"=" -f2)
                                           TEMP_INNEN=`echo "scale=2;(${TEMP_INNEN}-32)*5/9"|bc -l`
                                          #Aussentemperatur:
                                           TEMP_AUSSEN=$(echo ${DATA}|cut -d'&' -f4 | cut -d"=" -f2)
                                           TEMP_AUSSEN=`echo "scale=2;(${TEMP_AUSSEN}-32)*5/9"|bc -l`
                                          #Taupunkt:
                                           TAUPUNKT=$(echo ${DATA}|cut -d'&' -f5 | cut -d"=" -f2)
                                           TAUPUNKT=`echo "scale=2;(${TAUPUNKT}-32)*5/9"|bc -l`
                                          #Chill-Faktor:
                                           CHILL=$(echo ${DATA}|cut -d'&' -f6 | cut -d"=" -f2)
                                           CHILL=`echo "scale=2;(${CHILL}-32)*5/9"|bc -l`
                                          #Innenluftfeuchte:
                                           FEUCHTE_INNEN=$(echo ${DATA}|cut -d'&' -f7 | cut -d"=" -f2)
                                          #Aussenluftfeuchte:
                                           FEUCHTE_AUSSEN=$(echo ${DATA}|cut -d'&' -f8 | cut -d"=" -f2)
                                          #Windgeschwindigkeit:
                                           WIND=$(echo ${DATA}|cut -d'&' -f9 | cut -d"=" -f2)
                                           WIND=`echo "scale=2;${WIND}*16094/10000"|bc -l`
                                          #Windgeschwindigkeit max:
                                           WIND_MAX=$(echo ${DATA}|cut -d'&' -f10 | cut -d"=" -f2)
                                           WIND_MAX=`echo "scale=2;${WIND_MAX}*16094/10000"|bc -l`
                                          #Windrichtung:
                                           WIND_DIR=$(echo ${DATA}|cut -d'&' -f11 | cut -d"=" -f2)
                                          #Luftdruck absolut:
                                           DRUCK_ABS=$(echo ${DATA}|cut -d'&' -f12 | cut -d"=" -f2)
                                           DRUCK_ABS=`echo "scale=2;${DRUCK_ABS}*33864/1000"|bc -l`
                                          #Luftdruck relativ:
                                           DRUCK_REL=$(echo ${DATA}|cut -d'&' -f13 | cut -d"=" -f2)
                                           DRUCK_REL=`echo "scale=2;${DRUCK_REL}*33864/1000"|bc -l`
                                          #Regen aktuell:
                                           REGEN_AKT=$(echo ${DATA}|cut -d'&' -f14 | cut -d"=" -f2)
                                           REGEN_AKT=`echo "scale=1;${REGEN_AKT}*254/10"|bc -l`
                                          #Regen Tag:
                                           REGEN_TAG=$(echo ${DATA}|cut -d'&' -f15 | cut -d"=" -f2)
                                           REGEN_TAG=`echo "scale=1;${REGEN_TAG}*254/10"|bc -l`
                                          #Regen Woche:
                                           REGEN_WOCHE=$(echo ${DATA}|cut -d'&' -f16 | cut -d"=" -f2)
                                           REGEN_WOCHE=`echo "scale=1;${REGEN_WOCHE}*254/10"|bc -l`
                                          #Regen Monat:
                                           REGEN_MONAT=$(echo ${DATA}|cut -d'&' -f17 | cut -d"=" -f2)
                                           REGEN_MONAT=`echo "scale=1;${REGEN_MONAT}*254/10"|bc -l`
                                          #Sonnenstrahlung:
                                           SONNE=$(echo ${DATA}|cut -d'&' -f18 | cut -d"=" -f2)
                                          #UV-Index:
                                           UV_INDEX=$(echo ${DATA}|cut -d'&' -f19 | cut -d"=" -f2)
                                        
                                          #Datum und Zeit abfragen
                                           DAT_ZEIT=`timedatectl |grep Local`
                                           DATUM=$(echo ${DAT_ZEIT}|cut -d' ' -f4)
                                           UHRZEIT=$(echo ${DAT_ZEIT}|cut -d' ' -f5)
                                        
                                        #Daten an ioB schicken
                                        
                                           curl --data "${DP_TEMP_INNEN}=$TEMP_INNEN&${DP_TEMP_AUSSEN}=$TEMP_AUSSEN&${DP_TAUPUNKT}=$TAUPUNKT&${DP_CHILL}=$CHILL&${DP_FEUCHTE_INNEN}=$FEUCHTE_INNEN&${DP_FEUCHTE_AUSSEN}=$FEUCHTE_AUSSEN&${DP_WIND}=$WIND&${DP_WIND_MAX}=$WIND_MAX&${DP_WIND_DIR}=$WIND_DIR&${DP_DRUCK_ABS}=$DRUCK_ABS&${DP_DRUCK_REL}=$DRUCK_REL&${DP_REGEN_AKT}=$REGEN_AKT&${DP_REGEN_TAG}=$REGEN_TAG&${DP_REGEN_WOCHE}=$REGEN_WOCHE&${DP_REGEN_MONAT}=$REGEN_MONAT&${DP_SONNE}=$SONNE&${DP_UV_INDEX}=$UV_INDEX&${DP_DATUM}=$DATUM&${DP_ZEIT}=$UHRZEIT&prettyPrint" http://${IPP}/setBulk
                                        
                                        if [ $debug == "true" ]; then
                                           # Datenfelder ausgeben
                                           echo Temperatur Innen: $TEMP_INNEN °C
                                           echo Temperatur Aussen: $TEMP_AUSSEN °C
                                           echo Taupunkt: $TAUPUNKT °C
                                           echo Chill-Faktor: $CHILL °C
                                           echo Luftfeuchte Innen: $FEUCHTE_INNEN %
                                           echo Luftfeuchte Aussen: $FEUCHTE_AUSSEN %
                                           echo Windgeschwindkeit: $WIND km/h
                                           echo max. Windgeschwindkeit: $WIND_MAX km/h
                                           echo Windrichtung: $WIND_DIR °
                                           echo Luftdruck absolut: $DRUCK_ABS hPa
                                           echo Luftdruck relativ: $DRUCK_REL hPa
                                           echo Regen aktuell: $REGEN_AKT mm
                                           echo Regen Tag: $REGEN_TAG mm
                                           echo Regen Woche: $REGEN_WOCHE mm
                                           echo Regen Monat: $REGEN_MONAT mm
                                           echo Sonnenstrahlung: $SONNE W/m^2
                                           echo UV-Index: $UV_INDEX
                                           echo Datum: $DATUM Zeit: $UHRZEIT
                                        fi
                                        
                                        done
                                        
                                        

                                        Zusätzlich sind die Datenpunkte anzulegen ( ich hab´s unter javascript.0.Wetterstation) und der Adapter (Simple RESTFul) zu installieren, sowie das Script im "Autostart" (crontab -e) zu platzieren (@SBorg hat das sehr schön beschrieben) - das war´s auch schon!

                                        Bei der Umrechnung der Windgeschwindigkeiten bin ich mir noch nicht sicher, leider bläst gerade kein Wind 🙂

                                        B Offline
                                        B Offline
                                        Berchemer
                                        wrote on last edited by
                                        #23

                                        @Latzi

                                        Ach ja... Da war noch das Bash-Script...
                                        Muss jetzt erst mal nachschauen, wie ich das nochmal mache 😉

                                        Datei erstellen, Skript hineinkopieren und als "/opt/iobroker/WS3500Abfrage.sh" abspeichern.

                                        Dann "crontab -e" als Befehl eingeben, den Editor aussuchen und am Ende der Datei "@reboot /opt/iobroker/WS3500Abfrage.sh &" eingeben. Richtig?

                                        Mache ich zumindest mal so...

                                        B LatziL 2 Replies Last reply
                                        0
                                        • B Berchemer

                                          @Latzi

                                          Ach ja... Da war noch das Bash-Script...
                                          Muss jetzt erst mal nachschauen, wie ich das nochmal mache 😉

                                          Datei erstellen, Skript hineinkopieren und als "/opt/iobroker/WS3500Abfrage.sh" abspeichern.

                                          Dann "crontab -e" als Befehl eingeben, den Editor aussuchen und am Ende der Datei "@reboot /opt/iobroker/WS3500Abfrage.sh &" eingeben. Richtig?

                                          Mache ich zumindest mal so...

                                          B Offline
                                          B Offline
                                          Berchemer
                                          wrote on last edited by
                                          #24

                                          @Berchemer

                                          Ok... Soweit eingegeben und natürlich die IP im Skript geändert.
                                          Und natürlich den Datenpunkt vergessen einzutragen.

                                          LatziL 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate
                                          FAQ Cloud / IOT
                                          HowTo: Node.js-Update
                                          HowTo: Backup/Restore
                                          Downloads
                                          BLOG

                                          256

                                          Online

                                          32.4k

                                          Users

                                          81.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe