Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Node-Red
  5. MQTT data für Influxdb in "value" konvertieren

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    23
    1
    1.3k

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.5k

MQTT data für Influxdb in "value" konvertieren

Geplant Angeheftet Gesperrt Verschoben Node-Red
2 Beiträge 2 Kommentatoren 338 Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • S Offline
    S Offline
    steffen_muc
    schrieb am zuletzt editiert von
    #1

    Hallo in die Runde,
    folgendes Problemchen. Ich sende per MQTT Daten von TFA Dostmann Temperatursensoren an den iobroker. Dort tauchen sie auch schoen auf als topic: "rtl_433/SENSORID/temperatur_C oder /humidity".

    Die Luftfeuchtigkeit erscheint schön als "Wert". z.b. "69".

    Nur die Temperatur selbst kommt als String an. z.B. "21.2 C".

    Nun möchte ich gern die Temperaturwerte in die influxdb übernehmen, was als String nicht sonderlich sinnvoll ist. Somit würde ich nun versuchen über Node Red für "jeden Sensor , any" der diesen Temperaturwert als String schickt, den String um " C" zu bereinigen und einen "Wert" draus zu machen und das Ganze dann wieder als MQTT-Output liefern. Da ich ein rechter Newbie im Bereich NodeRed und Functions bin und das gleich auch für RegEx gilt mal die Frage hier:

    Habe mal angefangen mit :

    {payload:parseFloat(msg.payload[".*"].rawValue.replace([ C],"")

    aber das funktioniert nicht und weiterhin würde ich ja auch gern noch die SensorID wieder mit Ausspucken ...

    Also

    input: rtl_433/SENSORID/temperatur_C (String)
    output: rtl_433/SENSORID/temperatur (Value)

    Ich hoffe sehr auf jemanden, der mir einen Hinweis gibt bzw. das mal zusammentippt, weil ich nicht davon ausgehe dass das schwierig ist :-)
    Vielen Dank schon einmal.
    Steffen

    M 1 Antwort Letzte Antwort
    0
    • S steffen_muc

      Hallo in die Runde,
      folgendes Problemchen. Ich sende per MQTT Daten von TFA Dostmann Temperatursensoren an den iobroker. Dort tauchen sie auch schoen auf als topic: "rtl_433/SENSORID/temperatur_C oder /humidity".

      Die Luftfeuchtigkeit erscheint schön als "Wert". z.b. "69".

      Nur die Temperatur selbst kommt als String an. z.B. "21.2 C".

      Nun möchte ich gern die Temperaturwerte in die influxdb übernehmen, was als String nicht sonderlich sinnvoll ist. Somit würde ich nun versuchen über Node Red für "jeden Sensor , any" der diesen Temperaturwert als String schickt, den String um " C" zu bereinigen und einen "Wert" draus zu machen und das Ganze dann wieder als MQTT-Output liefern. Da ich ein rechter Newbie im Bereich NodeRed und Functions bin und das gleich auch für RegEx gilt mal die Frage hier:

      Habe mal angefangen mit :

      {payload:parseFloat(msg.payload[".*"].rawValue.replace([ C],"")

      aber das funktioniert nicht und weiterhin würde ich ja auch gern noch die SensorID wieder mit Ausspucken ...

      Also

      input: rtl_433/SENSORID/temperatur_C (String)
      output: rtl_433/SENSORID/temperatur (Value)

      Ich hoffe sehr auf jemanden, der mir einen Hinweis gibt bzw. das mal zusammentippt, weil ich nicht davon ausgehe dass das schwierig ist :-)
      Vielen Dank schon einmal.
      Steffen

      M Online
      M Online
      MCU
      schrieb am zuletzt editiert von MCU
      #2

      @steffen_muc
      So vielleicht?

      iobroker-blockly-temp-werte-aus-string.PNG

      var TEMP_STR, TEST, VAR_TEMP_STR, Stelle;
      
      // Beschreibe diese Funktion …
      function WERT_ERSTELLEN(TEMP_STR) {
       console.log(TEMP_STR);
       Stelle = TEMP_STR.indexOf(' ') + 1;
       VAR_TEMP_STR = parseFloat((TEMP_STR.slice(0, Stelle - 1)));
       return VAR_TEMP_STR;
      }
      
      
      TEST = WERT_ERSTELLEN('21.2 C');
      console.log(TEST);
      
      

      Für Node-Red: replace(/ C/g,"")

      NUC i7 64GB mit Proxmox ---- Jarvis Infos Aktualisierungen der Doku auf Instagram verfolgen -> mcuiobroker Instagram
      Wenn Euch mein Vorschlag geholfen hat, bitte rechts "^" klicken.

      1 Antwort Letzte Antwort
      0
      Antworten
      • In einem neuen Thema antworten
      Anmelden zum Antworten
      • Älteste zuerst
      • Neuste zuerst
      • Meiste Stimmen


      Support us

      ioBroker
      Community Adapters
      Donate

      751

      Online

      32.5k

      Benutzer

      81.7k

      Themen

      1.3m

      Beiträge
      Community
      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
      ioBroker Community 2014-2025
      logo
      • Anmelden

      • Du hast noch kein Konto? Registrieren

      • Anmelden oder registrieren, um zu suchen
      • Erster Beitrag
        Letzter Beitrag
      0
      • Home
      • Aktuell
      • Tags
      • Ungelesen 0
      • Kategorien
      • Unreplied
      • Beliebt
      • GitHub
      • Docu
      • Hilfe