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. Erster Werte des Tages aus History auslesen

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.6k

Erster Werte des Tages aus History auslesen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascriptblockly
52 Beiträge 6 Kommentatoren 7.0k Aufrufe 4 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.
  • M MCU

    @Chrille1507 step: 60000 -> entspricht 1Minute (in ms) , dem Abstand zum nächsten Wert.

    C Offline
    C Offline
    Chrille1507
    schrieb am zuletzt editiert von
    #19

    @MCU Eine doofe Nachfrage bitte noch. Abstand zum nächsten Wert innerhalb der Datenbank? Also wenn jede Sekunde ein Wert in die Datenbank geschrieben wird, könnte ich theoretisch bei Step auch 1000 eintragen?

    M 1 Antwort Letzte Antwort
    0
    • C Chrille1507

      @MCU Eine doofe Nachfrage bitte noch. Abstand zum nächsten Wert innerhalb der Datenbank? Also wenn jede Sekunde ein Wert in die Datenbank geschrieben wird, könnte ich theoretisch bei Step auch 1000 eintragen?

      M Offline
      M Offline
      MCU
      schrieb am zuletzt editiert von
      #20

      @Chrille1507 Bei 7 Tagen, die du mit Abfrage auswertest, würde ich mir das gut überlegen! Das kommt evtl einiges an Daten zusammen? Das kann dann auch ein System auslasten!

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

      C 1 Antwort Letzte Antwort
      1
      • M MCU

        @Chrille1507 Bei 7 Tagen, die du mit Abfrage auswertest, würde ich mir das gut überlegen! Das kommt evtl einiges an Daten zusammen? Das kann dann auch ein System auslasten!

        C Offline
        C Offline
        Chrille1507
        schrieb am zuletzt editiert von Chrille1507
        #21

        @MCU Sehr guter Hinweis, vielen Dank.

        Dann macht es vielleicht mehr Sinn, die Abfrage auf einen Tag zu beschränken und einen zweiten Datenpunkt anzulegen, der nur seinen Wert mit dem ersten Datenpunkt vergleicht und diesen für 7 Tage festzulegen.
        Sind zwar etwas mehr Datenpunkte entlastet das System wahrscheinlich.

        Vielen Dank

        G 1 Antwort Letzte Antwort
        0
        • C Chrille1507

          @MCU Sehr guter Hinweis, vielen Dank.

          Dann macht es vielleicht mehr Sinn, die Abfrage auf einen Tag zu beschränken und einen zweiten Datenpunkt anzulegen, der nur seinen Wert mit dem ersten Datenpunkt vergleicht und diesen für 7 Tage festzulegen.
          Sind zwar etwas mehr Datenpunkte entlastet das System wahrscheinlich.

          Vielen Dank

          G Offline
          G Offline
          glitzi
          schrieb am zuletzt editiert von
          #22

          Noch ein kleines Problem:

          Folgende Fehlermeldung erhalte ich bei angefügtem Skript:

          24.11.2020, 21:40:00.049	[warn ]: javascript.0 (1126) TypeError: Cannot read property 'val' of undefined
              at Object.cb (script.js.Wasserzähler.Wasserzähler_Minuten_und_Tageswert:42:100)
              at change (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5297:71)
              at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/states/statesInRedis.js:234:41)
              at processImmediate (internal/timers.js:461:21)
          
          // Wasserzähler summieren
          createState('WasserzählerSumme', function () {
            on({id: "mqtt.0.ESP_Easy.Wasser.Count"/*ESP_Easy/Wasser/Count*/, change: "any"}, function (obj) {
              var value = obj.state.val;
              var oldValue = obj.oldState.val;
              setState('WasserzählerSumme'/*WasserzählerSumme*/, (getState('WasserzählerSumme').val + getState("mqtt.0.ESP_Easy.Wasser.Count").val / 60)
              , true);
            });
          });
          
          // Wasser Tageswert
          schedule1 =  schedule('{"time":{"exactTime":true,"start":"23:59"},"period":{"days":1}}', function () {
          
          createState('Wasserzähler_Tageswert');
          
          sendTo('influxdb.0', 'getHistory', {
              id: 'javascript.0.WasserzählerSumme',
              options: {
                  start:      getDateObject('00:00').getTime(),
                  count:      1,
                  aggregate: 'none' // or 'none' to get raw values
              }
          }, function (result) {
              var berechnung = Math.round((getState('javascript.0.WasserzählerSumme').val - result.result[1].val) * 100) / 100;
              setState('javascript.0.Wasserzähler_Tageswert', berechnung, true);
          });
          });
          
          //Wasser Tageswert hochlaufend
          schedule2 = schedule('* * * * *', function () {
          
          createState('Wasserzähler_Tageswert_hochlaufend');
          
          sendTo('influxdb.0', 'getHistory', {
              id: 'javascript.0.WasserzählerSumme',
              options: {
                  start:      getDateObject('00:00').getTime(),
                  count:      1,
                  aggregate: 'none' // or 'none' to get raw values
              }
          }, function (result) {
              var berechnung = Math.round((getState('javascript.0.WasserzählerSumme').val - result.result[1].val) * 100) / 100;
              setState('javascript.0.Wasserzähler_Tageswert_hochlaufend', berechnung, true);  
          });
          });
          
          M 1 Antwort Letzte Antwort
          0
          • G glitzi

            Noch ein kleines Problem:

            Folgende Fehlermeldung erhalte ich bei angefügtem Skript:

            24.11.2020, 21:40:00.049	[warn ]: javascript.0 (1126) TypeError: Cannot read property 'val' of undefined
                at Object.cb (script.js.Wasserzähler.Wasserzähler_Minuten_und_Tageswert:42:100)
                at change (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5297:71)
                at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/states/statesInRedis.js:234:41)
                at processImmediate (internal/timers.js:461:21)
            
            // Wasserzähler summieren
            createState('WasserzählerSumme', function () {
              on({id: "mqtt.0.ESP_Easy.Wasser.Count"/*ESP_Easy/Wasser/Count*/, change: "any"}, function (obj) {
                var value = obj.state.val;
                var oldValue = obj.oldState.val;
                setState('WasserzählerSumme'/*WasserzählerSumme*/, (getState('WasserzählerSumme').val + getState("mqtt.0.ESP_Easy.Wasser.Count").val / 60)
                , true);
              });
            });
            
            // Wasser Tageswert
            schedule1 =  schedule('{"time":{"exactTime":true,"start":"23:59"},"period":{"days":1}}', function () {
            
            createState('Wasserzähler_Tageswert');
            
            sendTo('influxdb.0', 'getHistory', {
                id: 'javascript.0.WasserzählerSumme',
                options: {
                    start:      getDateObject('00:00').getTime(),
                    count:      1,
                    aggregate: 'none' // or 'none' to get raw values
                }
            }, function (result) {
                var berechnung = Math.round((getState('javascript.0.WasserzählerSumme').val - result.result[1].val) * 100) / 100;
                setState('javascript.0.Wasserzähler_Tageswert', berechnung, true);
            });
            });
            
            //Wasser Tageswert hochlaufend
            schedule2 = schedule('* * * * *', function () {
            
            createState('Wasserzähler_Tageswert_hochlaufend');
            
            sendTo('influxdb.0', 'getHistory', {
                id: 'javascript.0.WasserzählerSumme',
                options: {
                    start:      getDateObject('00:00').getTime(),
                    count:      1,
                    aggregate: 'none' // or 'none' to get raw values
                }
            }, function (result) {
                var berechnung = Math.round((getState('javascript.0.WasserzählerSumme').val - result.result[1].val) * 100) / 100;
                setState('javascript.0.Wasserzähler_Tageswert_hochlaufend', berechnung, true);  
            });
            });
            
            M Offline
            M Offline
            MCU
            schrieb am zuletzt editiert von MCU
            #23

            @glitzi 67437e76-bd1e-4715-8480-bbe20433672d-image.png

            getState('javascript.0.WasserzählerSumme').val
            

            Da auch:

            09ae5f5c-c758-419d-9369-cdf4bb22c1ee-image.png

            Und hier:
            d3937aee-6849-4bef-9819-9ef4fcba6c93-image.png

            57f2e53e-46c7-467b-9ddc-577dc6db5db1-image.png

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

            G 1 Antwort Letzte Antwort
            0
            • M MCU

              @glitzi 67437e76-bd1e-4715-8480-bbe20433672d-image.png

              getState('javascript.0.WasserzählerSumme').val
              

              Da auch:

              09ae5f5c-c758-419d-9369-cdf4bb22c1ee-image.png

              Und hier:
              d3937aee-6849-4bef-9819-9ef4fcba6c93-image.png

              57f2e53e-46c7-467b-9ddc-577dc6db5db1-image.png

              G Offline
              G Offline
              glitzi
              schrieb am zuletzt editiert von
              #24

              @MCU

              Was ist falsch, stehe auf dem Schlauch ;-)

              M 1 Antwort Letzte Antwort
              0
              • G glitzi

                @MCU

                Was ist falsch, stehe auf dem Schlauch ;-)

                M Offline
                M Offline
                MCU
                schrieb am zuletzt editiert von
                #25

                @glitzi Ich denke das (javascript.0. ..... davor muß.

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

                G paul53P 2 Antworten Letzte Antwort
                0
                • M MCU

                  @glitzi Ich denke das (javascript.0. ..... davor muß.

                  G Offline
                  G Offline
                  glitzi
                  schrieb am zuletzt editiert von
                  #26

                  @MCU

                  Kommt trotzdem

                  // Wasserzähler summieren
                  createState('WasserzählerSumme', function () {
                    on({id: "mqtt.0.ESP_Easy.Wasser.Count"/*ESP_Easy/Wasser/Count*/, change: "any"}, function (obj) {
                      var value = obj.state.val;
                      var oldValue = obj.oldState.val;
                      setState('javascript.0.WasserzählerSumme'/*WasserzählerSumme*/, (getState('javascript.0.WasserzählerSumme').val + getState("mqtt.0.ESP_Easy.Wasser.Count").val / 60)
                      , true);
                    });
                  });
                  
                  // Wasser Tageswert
                  schedule1 =  schedule('{"time":{"exactTime":true,"start":"23:59"},"period":{"days":1}}', function () {
                  
                  createState('Wasserzähler_Tageswert');
                  
                  sendTo('influxdb.0', 'getHistory', {
                      id: 'javascript.0.WasserzählerSumme',
                      options: {
                          start:      getDateObject('00:00').getTime(),
                          count:      1,
                          aggregate: 'none' // or 'none' to get raw values
                      }
                  }, function (result) {
                      var berechnung = Math.round((getState('javascript.0.WasserzählerSumme').val - result.result[1].val) * 100) / 100;
                      setState('javascript.0.Wasserzähler_Tageswert', berechnung, true);
                  });
                  });
                  
                  //Wasser Tageswert hochlaufend
                  schedule2 = schedule('* * * * *', function () {
                  
                  createState('Wasserzähler_Tageswert_hochlaufend');
                  
                  sendTo('influxdb.0', 'getHistory', {
                      id: 'javascript.0.WasserzählerSumme',
                      options: {
                          start:      getDateObject('00:00').getTime(),
                          count:      1,
                          aggregate: 'none' // or 'none' to get raw values
                      }
                  }, function (result) {
                      var berechnung = Math.round((getState('javascript.0.WasserzählerSumme').val - result.result[1].val) * 100) / 100;
                      setState('javascript.0.Wasserzähler_Tageswert_hochlaufend', berechnung, true);  
                  });
                  });
                  
                  M 1 Antwort Letzte Antwort
                  0
                  • M MCU

                    @glitzi Ich denke das (javascript.0. ..... davor muß.

                    paul53P Offline
                    paul53P Offline
                    paul53
                    schrieb am zuletzt editiert von paul53
                    #27

                    @MCU sagte:

                    Ich denke das (javascript.0. ..... davor muß.

                    Wenn das Script unter der Instanz 0 läuft, funktionieren beide Versionen. Außerdem kommt die Warnung aus Zeile 42 zu

                    result.result[1].val
                    

                    Ein eigener Test hat ergeben, dass bei count = 1 richtig wäre

                    result.result[0].val
                    

                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                    1 Antwort Letzte Antwort
                    0
                    • G glitzi

                      @MCU

                      Kommt trotzdem

                      // Wasserzähler summieren
                      createState('WasserzählerSumme', function () {
                        on({id: "mqtt.0.ESP_Easy.Wasser.Count"/*ESP_Easy/Wasser/Count*/, change: "any"}, function (obj) {
                          var value = obj.state.val;
                          var oldValue = obj.oldState.val;
                          setState('javascript.0.WasserzählerSumme'/*WasserzählerSumme*/, (getState('javascript.0.WasserzählerSumme').val + getState("mqtt.0.ESP_Easy.Wasser.Count").val / 60)
                          , true);
                        });
                      });
                      
                      // Wasser Tageswert
                      schedule1 =  schedule('{"time":{"exactTime":true,"start":"23:59"},"period":{"days":1}}', function () {
                      
                      createState('Wasserzähler_Tageswert');
                      
                      sendTo('influxdb.0', 'getHistory', {
                          id: 'javascript.0.WasserzählerSumme',
                          options: {
                              start:      getDateObject('00:00').getTime(),
                              count:      1,
                              aggregate: 'none' // or 'none' to get raw values
                          }
                      }, function (result) {
                          var berechnung = Math.round((getState('javascript.0.WasserzählerSumme').val - result.result[1].val) * 100) / 100;
                          setState('javascript.0.Wasserzähler_Tageswert', berechnung, true);
                      });
                      });
                      
                      //Wasser Tageswert hochlaufend
                      schedule2 = schedule('* * * * *', function () {
                      
                      createState('Wasserzähler_Tageswert_hochlaufend');
                      
                      sendTo('influxdb.0', 'getHistory', {
                          id: 'javascript.0.WasserzählerSumme',
                          options: {
                              start:      getDateObject('00:00').getTime(),
                              count:      1,
                              aggregate: 'none' // or 'none' to get raw values
                          }
                      }, function (result) {
                          var berechnung = Math.round((getState('javascript.0.WasserzählerSumme').val - result.result[1].val) * 100) / 100;
                          setState('javascript.0.Wasserzähler_Tageswert_hochlaufend', berechnung, true);  
                      });
                      });
                      
                      M Offline
                      M Offline
                      MCU
                      schrieb am zuletzt editiert von
                      #28

                      @glitzi Welcher Wert steht im DP: javascript.0.WasserzählerSumme

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

                      G 1 Antwort Letzte Antwort
                      0
                      • M MCU

                        @glitzi Welcher Wert steht im DP: javascript.0.WasserzählerSumme

                        G Offline
                        G Offline
                        glitzi
                        schrieb am zuletzt editiert von
                        #29

                        @MCU

                        da steht 2

                        G 1 Antwort Letzte Antwort
                        0
                        • G glitzi

                          @MCU

                          da steht 2

                          G Offline
                          G Offline
                          glitzi
                          schrieb am zuletzt editiert von
                          #30

                          @glitzi

                          so kommt der gleich Fehler in Zeile 42?

                          3bd76916-1bec-48ad-ba47-2aeaf3a46bf7-image.png

                          paul53P 1 Antwort Letzte Antwort
                          0
                          • G glitzi

                            @glitzi

                            so kommt der gleich Fehler in Zeile 42?

                            3bd76916-1bec-48ad-ba47-2aeaf3a46bf7-image.png

                            paul53P Offline
                            paul53P Offline
                            paul53
                            schrieb am zuletzt editiert von paul53
                            #31

                            @glitzi
                            Ich erhalte die Warnung auch beim Test mit

                            result.result[1].val
                            

                            Mit count = 1 sollte das Array nur einen Wert enthalten und das ist

                            result.result[0]
                            

                            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                            Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                            G 1 Antwort Letzte Antwort
                            0
                            • paul53P paul53

                              @glitzi
                              Ich erhalte die Warnung auch beim Test mit

                              result.result[1].val
                              

                              Mit count = 1 sollte das Array nur einen Wert enthalten und das ist

                              result.result[0]
                              
                              G Offline
                              G Offline
                              glitzi
                              schrieb am zuletzt editiert von
                              #32

                              @paul53

                              Ohh... das wars !!!!!

                              paul53P 1 Antwort Letzte Antwort
                              0
                              • G glitzi

                                @paul53

                                Ohh... das wars !!!!!

                                paul53P Offline
                                paul53P Offline
                                paul53
                                schrieb am zuletzt editiert von
                                #33

                                @glitzi sagte:

                                das wars

                                Wie bist Du hierauf gekommen ?

                                Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                G 1 Antwort Letzte Antwort
                                0
                                • paul53P paul53

                                  @glitzi sagte:

                                  das wars

                                  Wie bist Du hierauf gekommen ?

                                  G Offline
                                  G Offline
                                  glitzi
                                  schrieb am zuletzt editiert von
                                  #34

                                  @paul53

                                  Gute Frage ;-) beim vielen probieren bestimmt etwas übersehen.

                                  1 Antwort Letzte Antwort
                                  0
                                  • C Offline
                                    C Offline
                                    Chrille1507
                                    schrieb am zuletzt editiert von
                                    #35

                                    Hallo,
                                    passend zum Thema habe ich eine ähnliche Lösung gefunden, die vielleicht auch in Zukunft anderen hilft, die wie ich Probleme mit 'getHistory' haben.
                                    Die gewünschten Daten können auch mit folgenden Befehl ausgegeben werden:

                                    
                                    sendTo('influxdb.0', 'query', 'SELECT max("value") FROM "***" WHERE time > now() - 7d'
                                    

                                    In diesem Beispiel wird der maximale Wert (max("value")) des Datenpunktes ("***") der letzten 7 Tage ("now() - 7d") ausgegeben. So funktioniert es bei mir wunderbar.
                                    Aber Achtung: Die Ausgabe erfolgt als Array.

                                    M 1 Antwort Letzte Antwort
                                    0
                                    • C Chrille1507

                                      Hallo,
                                      passend zum Thema habe ich eine ähnliche Lösung gefunden, die vielleicht auch in Zukunft anderen hilft, die wie ich Probleme mit 'getHistory' haben.
                                      Die gewünschten Daten können auch mit folgenden Befehl ausgegeben werden:

                                      
                                      sendTo('influxdb.0', 'query', 'SELECT max("value") FROM "***" WHERE time > now() - 7d'
                                      

                                      In diesem Beispiel wird der maximale Wert (max("value")) des Datenpunktes ("***") der letzten 7 Tage ("now() - 7d") ausgegeben. So funktioniert es bei mir wunderbar.
                                      Aber Achtung: Die Ausgabe erfolgt als Array.

                                      M Offline
                                      M Offline
                                      MCU
                                      schrieb am zuletzt editiert von
                                      #36

                                      @Chrille1507 Fehlt noch ne Klammer am Ende?

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

                                      C 1 Antwort Letzte Antwort
                                      0
                                      • M MCU

                                        @Chrille1507 Fehlt noch ne Klammer am Ende?

                                        C Offline
                                        C Offline
                                        Chrille1507
                                        schrieb am zuletzt editiert von
                                        #37

                                        @MCU Jein. Bei mir geht es dann mit einer Function weiter. Soll ich die Klammer ergänzen?

                                        M 1 Antwort Letzte Antwort
                                        0
                                        • C Chrille1507

                                          @MCU Jein. Bei mir geht es dann mit einer Function weiter. Soll ich die Klammer ergänzen?

                                          M Offline
                                          M Offline
                                          MCU
                                          schrieb am zuletzt editiert von
                                          #38

                                          @Chrille1507 Oder auch die komplette function, nur so ist es etwas verwirrend?

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

                                          C 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

                                          511

                                          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