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. Visualisierung
  4. Flot Bar Tageswert

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    3.9k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.2k

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.5k

Flot Bar Tageswert

Geplant Angeheftet Gesperrt Verschoben Visualisierung
14 Beiträge 3 Kommentatoren 803 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.
  • NegaleinN Offline
    NegaleinN Offline
    Negalein
    Global Moderator
    schrieb am zuletzt editiert von
    #5

    @Homoran:

    Am Tagesende mit einem Script in einen anderen Datenpunkt schreiben und diesen loggen `

    Danke, das wars!

    Hatte eh ein JS hier aus dem Forum noch laufen!

    ° Node.js & System Update ---> sudo apt update, iob stop, sudo apt full-upgrade
    ° Node.js Fixer ---> iob nodejs-update
    ° Fixer ---> iob fix

    1 Antwort Letzte Antwort
    0
    • NegaleinN Offline
      NegaleinN Offline
      Negalein
      Global Moderator
      schrieb am zuletzt editiert von
      #6

      @Homoran:

      je nachdem wie du den Wert loggst, diesen nur einmal um 23:59 loggen

      ODER:

      Am Tagesende mit einem Script in einen anderen Datenpunkt schreiben und diesen loggen `

      Hallo Rainer!

      Ach kacke, das wars doch nicht! :(

      Gestern hat es einen Balken angezeigt, heute wieder mehrere Balken!

      Kannst du mir Tipps geben, wie ich den Wert nur einmal um 23:59 loggen kann?

      Danke

      ° Node.js & System Update ---> sudo apt update, iob stop, sudo apt full-upgrade
      ° Node.js Fixer ---> iob nodejs-update
      ° Fixer ---> iob fix

      1 Antwort Letzte Antwort
      0
      • HomoranH Nicht stören
        HomoranH Nicht stören
        Homoran
        Global Moderator Administrators
        schrieb am zuletzt editiert von
        #7

        womit loggst du denn?

        gibt es da eine Konfiguration?

        oder einen Cron?

        Wenn das alles nicht möglich ist musst du es mit einem Script/Blockly machen, das um 23:59 den aktuellen Wert von dem einen Datenpunkt in einen anderen schreibt.

        Gruß

        Rainer

        kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

        1 Antwort Letzte Antwort
        0
        • NegaleinN Offline
          NegaleinN Offline
          Negalein
          Global Moderator
          schrieb am zuletzt editiert von
          #8

          @Homoran:

          womit loggst du denn?

          gibt es da eine Konfiguration?

          oder einen Cron?

          Wenn das alles nicht möglich ist musst du es mit einem Script/Blockly machen, das um 23:59 den aktuellen Wert von dem einen Datenpunkt in einen anderen schreibt. `

          Mit diesem Script komm ich an die Daten der PV:

          var request = require("request");
          
          var myJson = {};
          
          var pfad = "Fronius_Symo_Hybrid.";
          
          var idDAY_ENERGY        = pfad + "ENERGY_DAY";
          var idPAC               = pfad + "PAC";
          var idYEAR_ENERGY       = pfad + "ENERGY_YEAR";
          var idTOTAL_ENERGY      = pfad + "ENERGY_TOTAL";
          
          createState(idDAY_ENERGY, 0, {
              name: 'Energie Tag',
              desc: 'Energie Tag',
              type: 'number',
              role: 'value',
              unit: 'Wh'
          });
          
          createState(idPAC, 0, {
              name: 'Leistung',
              desc: 'Leistung',
              type: 'number',
              role: 'value',
              unit: 'W'
          });
          
          createState(idYEAR_ENERGY, 0, {
              name: 'Energie Jahr',
              desc: 'Energie Jahr',
              type: 'number',
              role: 'value',
              unit: 'Wh'
          });
          
          createState(idTOTAL_ENERGY, 0, {
              name: 'Energie Total',
              desc: 'Energie Total',
              type: 'number',
              role: 'value',
              unit: 'Wh'
          });
          
          function parseJson(text) {
              if (text === "") return {};
              try {
                  json = JSON.parse(text);
              } catch (ex) {
                  json = {};
              }
              if(!json) json = {};
              return json;
          }
          
          function readJson(url, callback) {
              request(url, function (err, state, body){
                  if (body) {
                      var json = parseJson(body);
                      callback(null, json);
                  } else {
                      var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                      log(error, "warn");  
                      callback(error, null);
                  }
              });
          }
          
          var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System';
          
          function main() {
              readJson(url, function(err,json) {
                  if(!err) {
                      myJson = json;
                      log("DAY_ENERGY: "      + myJson.Body.Data.DAY_ENERGY.Values[1],"info");
                      log("PAC: "             + myJson.Body.Data.PAC.Values[1],"info");
                      log("YEAR_ENERGY: "     + myJson.Body.Data.YEAR_ENERGY.Values[1],"info");
                      log("TOTAL_ENERGY: "    + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info");
                      setState(idDAY_ENERGY   ,myJson.Body.Data.DAY_ENERGY.Values[1]);
                      setState(idPAC          ,myJson.Body.Data.PAC.Values[1]);
                      setState(idYEAR_ENERGY  ,myJson.Body.Data.YEAR_ENERGY.Values[1]);
                      setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]);
                  } else {
                      log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn");
                      myJson = {};
                  }
              });
          }
          
          schedule("*/10 * * * *", function () { // alle 10 Minuten die Werte abfragen
              main();
          });
          
          // Beim Skriptstart die Werte abfragen
          setTimeout(main,500);
          

          Aufzeichnen lass ich es dann unter "Objekte" javascript.0.Fronius_Symo_Hybrid.ENERGY_DAY mit dem Schraubenschlüssel.
          9441_objects_-iobroker__1.png

          Leider sieht die Grafik dort auch so aus:
          9441_objects_-iobroker__2.png

          ° Node.js & System Update ---> sudo apt update, iob stop, sudo apt full-upgrade
          ° Node.js Fixer ---> iob nodejs-update
          ° Fixer ---> iob fix

          1 Antwort Letzte Antwort
          0
          • HomoranH Nicht stören
            HomoranH Nicht stören
            Homoran
            Global Moderator Administrators
            schrieb am zuletzt editiert von
            #9

            Geht doch! ;-)

            Danke, damit kann ich helfen.

            @Negalein:

            Mit diesem Script komm ich an die Daten der PV: `

            und damit beantwortest du meine Frage:
            @Homoran:

            gibt es da … einen Cron? `

            den gibt es wie üblich fast ganz zum Schluss:

            schedule("*/10 * * * *", function () { // alle 10 Minuten die Werte abfragen
                main();
            

            dort werden alle 10 Minuten die Werte abgefragt.

            ich habe jetzt das Skript nicht komplett angesehen (sondern nur nach dem Cron gesucht).

            Wenn du wirklich NUR am Abend den einen Wert brauchst, kannst du diesen Cron umschreiben auf:

            schedule("59 23 * * *", function () {
            

            Dann wird einmal um 23:59 der Wert ausgelesen.

            Sollten da noch andere Werte ausgelesen werden, die du alle 10 Minuten brauchst müsste man das Skript kopieren und die jeweils relevanten Punkte zu den entsprechenden Zeiten abgefragt werden.

            Gruß

            Rainer

            kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

            Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

            der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

            1 Antwort Letzte Antwort
            0
            • NegaleinN Offline
              NegaleinN Offline
              Negalein
              Global Moderator
              schrieb am zuletzt editiert von
              #10

              @Homoran:

              Sollten da noch andere Werte ausgelesen werden, die du alle 10 Minuten brauchst müsste man das Skript kopieren und die jeweils relevanten Punkte zu den entsprechenden Zeiten abgefragt werden. `

              Danke dir herzlich!

              Dann deaktiviere ich die anderen Werte im Script mit // und kopiere das ganze Script in ein neues.

              Müsste dann mit diesen 2 Scripts passen?!

              Leistung, Jahr, Total "alle 10 Minuten"

              var request = require("request");
              
              var myJson = {};
              
              var pfad = "Fronius_Symo_Hybrid.";
              
              //var idDAY_ENERGY        = pfad + "ENERGY_DAY";
              var idPAC               = pfad + "PAC";
              var idYEAR_ENERGY       = pfad + "ENERGY_YEAR";
              var idTOTAL_ENERGY      = pfad + "ENERGY_TOTAL";
              
              //createState(idDAY_ENERGY, 0, {
              //    name: 'Energie Tag',
              //    desc: 'Energie Tag',
              //    type: 'number',
              //    role: 'value',
              //    unit: 'Wh'
              //});
              
              createState(idPAC, 0, {
                  name: 'Leistung',
                  desc: 'Leistung',
                  type: 'number',
                  role: 'value',
                  unit: 'W'
              });
              
              createState(idYEAR_ENERGY, 0, {
                  name: 'Energie Jahr',
                  desc: 'Energie Jahr',
                  type: 'number',
                  role: 'value',
                  unit: 'Wh'
              });
              
              createState(idTOTAL_ENERGY, 0, {
                  name: 'Energie Total',
                  desc: 'Energie Total',
                  type: 'number',
                  role: 'value',
                  unit: 'Wh'
              });
              
              function parseJson(text) {
                  if (text === "") return {};
                  try {
                      json = JSON.parse(text);
                  } catch (ex) {
                      json = {};
                  }
                  if(!json) json = {};
                  return json;
              }
              
              function readJson(url, callback) {
                  request(url, function (err, state, body){
                      if (body) {
                          var json = parseJson(body);
                          callback(null, json);
                      } else {
                          var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                          log(error, "warn");  
                          callback(error, null);
                      }
                  });
              }
              
              var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System';
              
              function main() {
                  readJson(url, function(err,json) {
                      if(!err) {
                          myJson = json;
                          log("DAY_ENERGY: "      + myJson.Body.Data.DAY_ENERGY.Values[1],"info");
                          log("PAC: "             + myJson.Body.Data.PAC.Values[1],"info");
                          log("YEAR_ENERGY: "     + myJson.Body.Data.YEAR_ENERGY.Values[1],"info");
                          log("TOTAL_ENERGY: "    + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info");
                          setState(idDAY_ENERGY   ,myJson.Body.Data.DAY_ENERGY.Values[1]);
                          setState(idPAC          ,myJson.Body.Data.PAC.Values[1]);
                          setState(idYEAR_ENERGY  ,myJson.Body.Data.YEAR_ENERGY.Values[1]);
                          setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]);
                      } else {
                          log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn");
                          myJson = {};
                      }
                  });
              }
              
              schedule("*/10 * * * *", function () { // alle 10 Minuten die Werte abfragen
                  main();
              });
              
              // Beim Skriptstart die Werte abfragen
              setTimeout(main,500);
              

              Tag immer um 23:59

              var request = require("request");
              
              var myJson = {};
              
              var pfad = "Fronius_Symo_Hybrid.";
              
              var idDAY_ENERGY        = pfad + "ENERGY_DAY";
              //var idPAC               = pfad + "PAC";
              //var idYEAR_ENERGY       = pfad + "ENERGY_YEAR";
              //var idTOTAL_ENERGY      = pfad + "ENERGY_TOTAL";
              
              createState(idDAY_ENERGY, 0, {
                  name: 'Energie Tag',
                  desc: 'Energie Tag',
                  type: 'number',
                  role: 'value',
                  unit: 'Wh'
              });
              
              //createState(idPAC, 0, {
              //    name: 'Leistung',
              //   desc: 'Leistung',
              //    type: 'number',
              //    role: 'value',
              //    unit: 'W'
              //});
              
              //createState(idYEAR_ENERGY, 0, {
              //    name: 'Energie Jahr',
              //    desc: 'Energie Jahr',
              //    type: 'number',
              //    role: 'value',
              //    unit: 'Wh'
              //});
              
              //createState(idTOTAL_ENERGY, 0, {
              //    name: 'Energie Total',
              //    desc: 'Energie Total',
              //    type: 'number',
              //    role: 'value',
              //    unit: 'Wh'
              //});
              
              function parseJson(text) {
                  if (text === "") return {};
                  try {
                      json = JSON.parse(text);
                  } catch (ex) {
                      json = {};
                  }
                  if(!json) json = {};
                  return json;
              }
              
              function readJson(url, callback) {
                  request(url, function (err, state, body){
                      if (body) {
                          var json = parseJson(body);
                          callback(null, json);
                      } else {
                          var error = "(" + err + ") ERROR bei Abfrage von: " + url;
                          log(error, "warn");  
                          callback(error, null);
                      }
                  });
              }
              
              var url = 'http://10.0.1.90/solar_api/v1/GetInverterRealtimeData.cgi?Scope=System';
              
              function main() {
                  readJson(url, function(err,json) {
                      if(!err) {
                          myJson = json;
                          log("DAY_ENERGY: "      + myJson.Body.Data.DAY_ENERGY.Values[1],"info");
                          log("PAC: "             + myJson.Body.Data.PAC.Values[1],"info");
                          log("YEAR_ENERGY: "     + myJson.Body.Data.YEAR_ENERGY.Values[1],"info");
                          log("TOTAL_ENERGY: "    + myJson.Body.Data.TOTAL_ENERGY.Values[1],"info");
                          setState(idDAY_ENERGY   ,myJson.Body.Data.DAY_ENERGY.Values[1]);
                          setState(idPAC          ,myJson.Body.Data.PAC.Values[1]);
                          setState(idYEAR_ENERGY  ,myJson.Body.Data.YEAR_ENERGY.Values[1]);
                          setState(idTOTAL_ENERGY ,myJson.Body.Data.TOTAL_ENERGY.Values[1]);
                      } else {
                          log("Fehler beim Auslesen des JSON. Keine Daten erhalten.","warn");
                          myJson = {};
                      }
                  });
              }
              
              schedule("59 23 * * *", function () { // täglich um 23 Uhr 59 Minuten
                  main();
              });
              
              // Beim Skriptstart die Werte abfragen
              setTimeout(main,500);
              

              Kannst du bitte kurz drüberschaun?

              Danke

              ° Node.js & System Update ---> sudo apt update, iob stop, sudo apt full-upgrade
              ° Node.js Fixer ---> iob nodejs-update
              ° Fixer ---> iob fix

              1 Antwort Letzte Antwort
              0
              • HomoranH Nicht stören
                HomoranH Nicht stören
                Homoran
                Global Moderator Administrators
                schrieb am zuletzt editiert von
                #11

                @Negalein:

                Kannst du bitte kurz drüberschaun? `

                Kann ich!

                Hift dir aber nicht :lol:

                Ich lebe auch nur von Copy, paste, try and error ;-)

                Probiere es einfach aus und/oder warte bis sich hier jemand anderes meldet, der skripten kann.

                Gruß

                Rainer

                kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

                Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

                der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

                1 Antwort Letzte Antwort
                0
                • NegaleinN Offline
                  NegaleinN Offline
                  Negalein
                  Global Moderator
                  schrieb am zuletzt editiert von
                  #12

                  @Homoran:

                  Ich lebe auch nur von Copy, paste, try and error ;-) `

                  Dann bin ich nicht alleine! :lol: ;)

                  Aber Recht hast du. So lernt man am ehesten die Funktionen kennen und verstehen!

                  ° Node.js & System Update ---> sudo apt update, iob stop, sudo apt full-upgrade
                  ° Node.js Fixer ---> iob nodejs-update
                  ° Fixer ---> iob fix

                  1 Antwort Letzte Antwort
                  0
                  • D Offline
                    D Offline
                    dwm
                    schrieb am zuletzt editiert von
                    #13

                    Stell bei den Eingangsdaten den Typ auf Max,

                    und im Zeit-Tab die Aggregation auf 86400 Sekunden, dann wird der Tageswert angezeigt, ohne viel zu scripten …

                    1 Antwort Letzte Antwort
                    0
                    • NegaleinN Offline
                      NegaleinN Offline
                      Negalein
                      Global Moderator
                      schrieb am zuletzt editiert von
                      #14

                      @dwm:

                      Stell bei den Eingangsdaten den Typ auf Max,

                      und im Zeit-Tab die Aggregation auf 86400 Sekunden, dann wird der Tageswert angezeigt, ohne viel zu scripten … `

                      Danke

                      ° Node.js & System Update ---> sudo apt update, iob stop, sudo apt full-upgrade
                      ° Node.js Fixer ---> iob nodejs-update
                      ° Fixer ---> iob fix

                      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

                      517

                      Online

                      32.7k

                      Benutzer

                      82.4k

                      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