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 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
                                        • 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...

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

                                          @Berchemer
                                          Ja genau so! Rechte beim Script beachten (wenn nicht root) und VORHER Datenpunkte anlegen

                                          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

                                          696

                                          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