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. gezielt Werte aus InfluxDB mit Telegram verschicken

NEWS

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

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

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

gezielt Werte aus InfluxDB mit Telegram verschicken

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
2 Beiträge 2 Kommentatoren 329 Aufrufe 1 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.
  • E Offline
    E Offline
    Einencool
    schrieb am zuletzt editiert von
    #1

    Hallo zusammen,
    ich bin neu hier im Forum angemeldet, weil ich mir seit 3 Tagen immer wieder Gedanken mache, wie ich Daten aus der InfluxDB per Skript (am liebsten Blockly) auslese und diese anschließend per Telegram versenden kann.

    Ich habe ein Balkonkraftwerk mit einer AhoiDTU.
    Die Werte speichere ich per MQTT in die InfluxDB.
    Den "Yield.Day" Wert kann ich auch soweit sehen und kann mir auch alles grafisch anzeigen lassen.

    Wenn ich allerdings unterwegs bin, möchte ich gerne den "jeweiligen" Tagesertrag der letzten 7 Tage per Telegram erhalten können.

    Da ich Programmiertechnisch nicht sehr erfahren bin, würde ich mich da über Hilfe von euch sehr freuen.

    Ich habe schon gesehen, mit "getHistory" kann man Werte per Skript aus der DB auslesen.
    Dann hört es aber bei mir leider schon auf :-(
    Mit den Blocklys habe ich mich soweit schon ganz gut angefreundet und habe nach den bekannten Anleitungen im Netz auch hinbekommen, meine ganzen "direkt zugänglichen" Werte auch per Telegram zu erhalten.

    Leider fehlt mir erstmal der Ansatz, wie ich das für die letzten 7 Tage machen muss.
    Brauche ich dann für jeden Tag einen eigenen Datenpunkt? Und in den Datenpunkt schreibe ich dann irgendwie den letzten Wert des Tages (z.B. um 23:59)? Wenn ich mir allerdings jetzt um diese Zeit den Wert der "letzten 10min." anzeigen lassen möchte, zeigt er mir nur einen Wert von Februar an, an dem ich das System in Betrieb genommen habe. Erst wenn ich die Zeit erhöhe, zeigt er mir auch den Wert des heute zuletzt gesendeten Wertes an...

    Hatte auch schon gedacht, den "heutigen" Wert um 23:59 in einen Datenpunkt zu schreiben und diesen dann jeden Tag per Blockly um einen Tag verschiebe.
    Damit hätte ich nach 1 Woche auch jeweils die letzten 7 Tage, dachte nur, es wäre einfacher, wenn ich schon alle Werte vorliegen habe... :-)

    Also falls mir da jemand weiterhelfen möchte, wäre ich sehr dankbar dafür :-)
    Gruß
    Chris

    W 1 Antwort Letzte Antwort
    0
    • E Einencool

      Hallo zusammen,
      ich bin neu hier im Forum angemeldet, weil ich mir seit 3 Tagen immer wieder Gedanken mache, wie ich Daten aus der InfluxDB per Skript (am liebsten Blockly) auslese und diese anschließend per Telegram versenden kann.

      Ich habe ein Balkonkraftwerk mit einer AhoiDTU.
      Die Werte speichere ich per MQTT in die InfluxDB.
      Den "Yield.Day" Wert kann ich auch soweit sehen und kann mir auch alles grafisch anzeigen lassen.

      Wenn ich allerdings unterwegs bin, möchte ich gerne den "jeweiligen" Tagesertrag der letzten 7 Tage per Telegram erhalten können.

      Da ich Programmiertechnisch nicht sehr erfahren bin, würde ich mich da über Hilfe von euch sehr freuen.

      Ich habe schon gesehen, mit "getHistory" kann man Werte per Skript aus der DB auslesen.
      Dann hört es aber bei mir leider schon auf :-(
      Mit den Blocklys habe ich mich soweit schon ganz gut angefreundet und habe nach den bekannten Anleitungen im Netz auch hinbekommen, meine ganzen "direkt zugänglichen" Werte auch per Telegram zu erhalten.

      Leider fehlt mir erstmal der Ansatz, wie ich das für die letzten 7 Tage machen muss.
      Brauche ich dann für jeden Tag einen eigenen Datenpunkt? Und in den Datenpunkt schreibe ich dann irgendwie den letzten Wert des Tages (z.B. um 23:59)? Wenn ich mir allerdings jetzt um diese Zeit den Wert der "letzten 10min." anzeigen lassen möchte, zeigt er mir nur einen Wert von Februar an, an dem ich das System in Betrieb genommen habe. Erst wenn ich die Zeit erhöhe, zeigt er mir auch den Wert des heute zuletzt gesendeten Wertes an...

      Hatte auch schon gedacht, den "heutigen" Wert um 23:59 in einen Datenpunkt zu schreiben und diesen dann jeden Tag per Blockly um einen Tag verschiebe.
      Damit hätte ich nach 1 Woche auch jeweils die letzten 7 Tage, dachte nur, es wäre einfacher, wenn ich schon alle Werte vorliegen habe... :-)

      Also falls mir da jemand weiterhelfen möchte, wäre ich sehr dankbar dafür :-)
      Gruß
      Chris

      W Offline
      W Offline
      WasserStrom
      schrieb am zuletzt editiert von
      #2

      @einencool

      Hi,

      ich kenne AhoiDTU nicht.
      Der "Yield.Day" hört sich aber schon mal gut an und mir scheint, dass du ihn schon in influxdb speicherst.

      Mit dem folgenden Blockly kannst du ihn aus influxDB auslesen und und über 7 Tage summieren.
      Das Versenden über Telegram funktioniert so, wie du es schon für die Einzelwerte geschafft hast.

      blockly_influxdb-anfrage.png

      var end, start, result, wertesumme, i, wert, zeit;
      
      
      // Get history from influxdb adapter
      end = (new Date().getTime());
      start = parseFloat(end) - parseFloat(7) * 3600000;
      sendTo("influxdb.0", "getHistory", {
        "id": 'AhoiDTU.0.Yield.Day',
        "options": {start: start, end: end, aggregate: "none"}
      }, async function (result) {
         console.log('Ergebnis der Abfrage:');
       // Rückmeldung von influxDB ausgeben:
       console.log(result);
       console.log('Die Einzelwerte:');
       wertesumme = 0;
       // Rückmeldung von influxDB auswerten:
       var i_end = parseFloat(getAttr(result, 'result').length) - 1;
       var i_inc = 1;
       if (0 > i_end) {
         i_inc = -i_inc;
       }
       for (i = 0; i_inc >= 0 ? i <= i_end : i >= i_end; i += i_inc) {
         wert = getAttr(result, (['result.',i,'.val'].join('')));
         wertesumme = (typeof wertesumme == 'number' ? wertesumme : 0) + wert;
         zeit = getAttr(result, (['result.',i,'.ts'].join('')));
         console.log((['Wert: ',wert,' Zeit: ',formatDate(getDateObject(zeit), "TT.MM.JJJJ SS:mm:ss")].join('')));
       }
       console.log(('Die Summe aller Werte: ' + String(wertesumme)));
       });
      

      Falls du übrigens die influxDB-Abfrage anpassen möchtest, ist hier die Hilfeseite:
      https://github.com/ioBroker/ioBroker.influxdb

      Grüße,
      Philipp

      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

      821

      Online

      32.4k

      Benutzer

      81.5k

      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