Skip to content
  • Home
  • 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
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. Erster Werte des Tages aus History auslesen

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    772

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

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

Erster Werte des Tages aus History auslesen

Scheduled Pinned Locked Moved Skripten / Logik
javascriptblockly
52 Posts 6 Posters 7.1k Views 4 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.
  • 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 Online
    M Online
    MCU
    wrote on last edited by
    #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 Reply Last reply
    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
      wrote on last edited by 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 Reply Last reply
      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
        wrote on last edited by
        #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 Reply Last reply
        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 Online
          M Online
          MCU
          wrote on last edited by 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 Reply Last reply
          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
            wrote on last edited by
            #24

            @MCU

            Was ist falsch, stehe auf dem Schlauch ;-)

            M 1 Reply Last reply
            0
            • G glitzi

              @MCU

              Was ist falsch, stehe auf dem Schlauch ;-)

              M Online
              M Online
              MCU
              wrote on last edited by
              #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 Replies Last reply
              0
              • M MCU

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

                G Offline
                G Offline
                glitzi
                wrote on last edited by
                #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 Reply Last reply
                0
                • M MCU

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

                  paul53P Offline
                  paul53P Offline
                  paul53
                  wrote on last edited by 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 Reply Last reply
                  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 Online
                    M Online
                    MCU
                    wrote on last edited by
                    #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 Reply Last reply
                    0
                    • M MCU

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

                      G Offline
                      G Offline
                      glitzi
                      wrote on last edited by
                      #29

                      @MCU

                      da steht 2

                      G 1 Reply Last reply
                      0
                      • G glitzi

                        @MCU

                        da steht 2

                        G Offline
                        G Offline
                        glitzi
                        wrote on last edited by
                        #30

                        @glitzi

                        so kommt der gleich Fehler in Zeile 42?

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

                        paul53P 1 Reply Last reply
                        0
                        • G glitzi

                          @glitzi

                          so kommt der gleich Fehler in Zeile 42?

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

                          paul53P Offline
                          paul53P Offline
                          paul53
                          wrote on last edited by 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 Reply Last reply
                          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
                            wrote on last edited by
                            #32

                            @paul53

                            Ohh... das wars !!!!!

                            paul53P 1 Reply Last reply
                            0
                            • G glitzi

                              @paul53

                              Ohh... das wars !!!!!

                              paul53P Offline
                              paul53P Offline
                              paul53
                              wrote on last edited by
                              #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 Reply Last reply
                              0
                              • paul53P paul53

                                @glitzi sagte:

                                das wars

                                Wie bist Du hierauf gekommen ?

                                G Offline
                                G Offline
                                glitzi
                                wrote on last edited by
                                #34

                                @paul53

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

                                1 Reply Last reply
                                0
                                • C Offline
                                  C Offline
                                  Chrille1507
                                  wrote on last edited by
                                  #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 Reply Last reply
                                  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 Online
                                    M Online
                                    MCU
                                    wrote on last edited by
                                    #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 Reply Last reply
                                    0
                                    • M MCU

                                      @Chrille1507 Fehlt noch ne Klammer am Ende?

                                      C Offline
                                      C Offline
                                      Chrille1507
                                      wrote on last edited by
                                      #37

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

                                      M 1 Reply Last reply
                                      0
                                      • C Chrille1507

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

                                        M Online
                                        M Online
                                        MCU
                                        wrote on last edited by
                                        #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 Reply Last reply
                                        0
                                        • M MCU

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

                                          C Offline
                                          C Offline
                                          Chrille1507
                                          wrote on last edited by
                                          #39

                                          @MCU Gerne. Anbei eine komplette Funktion als Beispiel.

                                          schedule('* * * * *', function() {
                                              sendTo('influxdb.0', 'query', 'SELECT max("value") FROM "Beipiel" WHERE time > now() - 7d', function(result) {
                                                  setState("Beispiel_Datenpunkt", JSON.stringify(result.result[0])); 
                                                  });
                                          });
                                          

                                          In diesem Beispiel würde jede Minute (schedule '* * * * *') der höchste Wert (max("value")) der letzten 7 Tage (time > now() - 7d) in einen Beispiel-Datenpunkt geschrieben werden.

                                          G 1 Reply Last reply
                                          0

                                          Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                                          Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                                          With your input, this post could be even better 💗

                                          Register Login
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          648

                                          Online

                                          32.8k

                                          Users

                                          82.7k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe