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. Off Topic
  4. Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.3k

Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern

Scheduled Pinned Locked Moved Off Topic
190 Posts 5 Posters 24.7k 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.
  • B Offline
    B Offline
    bitwicht
    wrote on last edited by
    #144

    @Marc-Berg

    Backup geht wohl nicht, hat schon jemand gemacht.
    Über die Shell läuft es seit 1 Minute.
    Wenn nicht muss ich den Timeout in der Config hoch setzen oder deaktivieren.

    1 Reply Last reply
    0
    • B Offline
      B Offline
      bitwicht
      wrote on last edited by
      #145

      @Marc Berg

      ich glaube das macht so keinen Sinn. Der Kopiert wohl noch 2 Tage ....
      Ich merke gerade ich schreibe alle meine Datenpunkte nahezu pro Sekunde in die Influx.

      Ich glaube ich muss die DB neu aufbauen mit diesen Downsampling-Bucket:
      https://forum.iobroker.net/topic/58462/datenaufzeichnung-retention-influxdb-2-0/21

      Marc BergM 1 Reply Last reply
      0
      • B bitwicht

        @Marc Berg

        ich glaube das macht so keinen Sinn. Der Kopiert wohl noch 2 Tage ....
        Ich merke gerade ich schreibe alle meine Datenpunkte nahezu pro Sekunde in die Influx.

        Ich glaube ich muss die DB neu aufbauen mit diesen Downsampling-Bucket:
        https://forum.iobroker.net/topic/58462/datenaufzeichnung-retention-influxdb-2-0/21

        Marc BergM Online
        Marc BergM Online
        Marc Berg
        Most Active
        wrote on last edited by Marc Berg
        #146

        @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

        Ich merke gerade ich schreibe alle meine Datenpunkte nahezu pro Sekunde in die Influx.

        Ja, das bricht wohl jeder Hardware irgendwann den Hals. Ich denke auch, in dieser Situation ist es das Beste, grundsätzlich neu anzufangen, die vorhandenen Daten aggregiert in ein anderes Bucket zu schreiben und sich zu überlegen, wie man schon ganz am Anfang die Datenflut begrenzen kann. Der Adapter bietet da ja einige Möglichkeiten.

        NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

        Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

        Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

        1 Reply Last reply
        0
        • B Offline
          B Offline
          bitwicht
          wrote on last edited by bitwicht
          #147

          @Marc-Berg

          Immerhin, wieder etwas gelernt.

          Wenn ich den Datenpunkt in die Influx schreiben lasse gibt es die Option: Blockzeit

          Verstehe ich das richtig, dass ich hier 5 Min einstellen könnte und er dann nur alle 5 Minuten einen Wert wegschreibt auch wenn es davon eine Veränderung gab?

          IO-B52.JPG

          Damit könnte ich die Datenflut auch etwas eingrenzen.

          Marc BergM 1 Reply Last reply
          0
          • B bitwicht

            @Marc-Berg

            Immerhin, wieder etwas gelernt.

            Wenn ich den Datenpunkt in die Influx schreiben lasse gibt es die Option: Blockzeit

            Verstehe ich das richtig, dass ich hier 5 Min einstellen könnte und er dann nur alle 5 Minuten einen Wert wegschreibt auch wenn es davon eine Veränderung gab?

            IO-B52.JPG

            Damit könnte ich die Datenflut auch etwas eingrenzen.

            Marc BergM Online
            Marc BergM Online
            Marc Berg
            Most Active
            wrote on last edited by
            #148

            @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

            Verstehe ich das richtig, dass ich hier 5 Min einstellen könnte und er dann nur alle 5 Minuten einen Wert wegschreibt auch wenn es davon eine Veränderung gab?

            Das ist eine Möglichkeit, ja. Ich persönlich finde es besser, den Haken "Nur Änderungen aufzeichnen" zu setzen und zusätzlich ausschließlich die minimale Differenz (je nach Eingangsdaten) einzutragen. Damit kann ich z.B. Temperaturänderungen von kleiner 0.2K ausfiltern, bekomme aber trotzdem kurzfristige signifikante Schwankungen mit, die mir mit der Blockzeit ggf. verloren gingen. Das ist aber natürlich sehr von den Eingangsdaten abhängig.

            NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

            Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

            Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

            1 Reply Last reply
            0
            • B Offline
              B Offline
              bitwicht
              wrote on last edited by
              #149

              @Marc-Berg

              Wenn ich ein neues Bucket anlege und den iobroker darauf umstelle, werden die measuremnts glaube automatisch neu erstellt und mit daten gefüllt.

              Wenn ich dann vom alten Bucket 2,3 measuremnts mit dem Befehl rüber kopiere, bleiben dann die neuen Daten erhalten? also wir das hinzugefügt ?

              from(bucket: "iobroker")
                |> range(start: -10y)
                |> filter(fn: (r) => r["_measurement"] == "test")
                |> to(bucket: "iobroker_tmp")
              
              1 Reply Last reply
              0
              • Marc BergM Online
                Marc BergM Online
                Marc Berg
                Most Active
                wrote on last edited by Marc Berg
                #150

                @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                Wenn ich ein neues Bucket anlege und den iobroker darauf umstelle, werden die measuremnts glaube automatisch neu erstellt und mit daten gefüllt.

                ja

                Wenn ich dann vom alten Bucket 2,3 measuremnts mit dem Befehl rüber kopiere, bleiben dann die neuen Daten erhalten? also wir das hinzugefügt ?

                ja, da geht nichts verloren.

                NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

                Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                1 Reply Last reply
                0
                • B Offline
                  B Offline
                  bitwicht
                  wrote on last edited by bitwicht
                  #151

                  @Marc-Berg

                  Weißt du zufällig ob ich das Delete-alter eines Buckets auch nachträglich ändern kann?
                  ZB: ich stelle es jetzt auf 1 Jahr und nach ein paar Monaten auf 6 Monate ?

                  Oder muss ich dann das Bucket umbenennen, ein neues anlagen und die Daten rüber schieben?

                  Sorry, habe gerade gesehen das es in den Settings einzustellen geht ....

                  Marc BergM 1 Reply Last reply
                  0
                  • B bitwicht

                    @Marc-Berg

                    Weißt du zufällig ob ich das Delete-alter eines Buckets auch nachträglich ändern kann?
                    ZB: ich stelle es jetzt auf 1 Jahr und nach ein paar Monaten auf 6 Monate ?

                    Oder muss ich dann das Bucket umbenennen, ein neues anlagen und die Daten rüber schieben?

                    Sorry, habe gerade gesehen das es in den Settings einzustellen geht ....

                    Marc BergM Online
                    Marc BergM Online
                    Marc Berg
                    Most Active
                    wrote on last edited by
                    #152

                    @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                    Sorry, habe gerade gesehen das es in den Settings einzustellen geht ....

                    Genau, oder auch über die Instanzeinstellungen des Adapters.

                    NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

                    Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                    Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                    1 Reply Last reply
                    0
                    • B Offline
                      B Offline
                      bitwicht
                      wrote on last edited by bitwicht
                      #153

                      @Marc-Berg

                      zu dem Script, verstehe ich das richtig:

                      import "timezone"
                       
                      option task = {name: "Downsampling Vb_Stromzaehler", cron: "15 0 * * *"}
                       
                      option location = timezone.location(name: "Europe/Berlin")
                       
                      data =
                          from(bucket: "ioBroker")
                              |> range(start: -2mo, stop: now())
                              |> filter(fn: (r) => r["_measurement"] == "Vb_Stromzaehler")
                              |> filter(fn: (r) => r["from"] == "system.adapter.javascript.0")
                              // Spalten "_start", "_stop", "ack", "from", "q", ausschliessen
                              |> drop(columns: ["ack", "q", "from"])
                       
                      data
                          |> aggregateWindow(every: 1d, fn: last, timeSrc: "_start")
                          // In Wh ohne Komma
                          |> toInt()
                          |> set(key: "_measurement", value: "Hauptzaehler") 
                          // Use the to() function to validate that the results look correct. This is optional.
                          |> to(bucket: "Stromverbrauch", org: "RBE")
                      

                      Was bedeutet:
                      name: "Downsampling Vb_Stromzaehler"
                      Ist das frei wählbar oder ein Bucket / Measurement ?

                      range(start: -2mo, stop: now())
                      Wenn das Script täglich läuft müsste doch auch -1d reichen weil er doch dann regelmäßig wegschreibt oder warum macht er hier -2mo ?

                      |> filter(fn: (r) => r["_measurement"] == "Vb_Stromzaehler")
                      |> filter(fn: (r) => r["from"] == "system.adapter.javascript.0")
                      er filtert nach measurement aber warum dann noch das from ?
                      ich habe hier immer: |> filter(fn: (r) => r["_field"] == "value")

                      |> set(key: "_measurement", value: "Hauptzaehler")
                      |> to(bucket: "Stromverbrauch", org: "RBE")
                      das heißt es wird in das bucket Stromverbrauch mit _measurement "Hauptzaehler" geschrieben oder ?

                      1 Reply Last reply
                      0
                      • Marc BergM Online
                        Marc BergM Online
                        Marc Berg
                        Most Active
                        wrote on last edited by
                        #154

                        @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                        Was bedeutet:
                        name: "Downsampling Vb_Stromzaehler"
                        Ist das frei wählbar oder ein Bucket / Measurement ?

                        Lege über die Oberfläche einfach mal einen neuen Task an. Dann siehst du, dass die Eingaben aus der Gui übernommen werden. Dies ist also einfach nur ein Name, der beliebig sein kann.

                        range(start: -2mo, stop: now())
                        Wenn das Script täglich läuft müsste doch auch -1d reichen weil er doch dann regelmäßig wegschreibt oder warum macht er hier -2mo ?

                        Wenn das Skript aus welchen Gründen auch immer mal nicht laufen sollte, ist es besser ein paar Tage weiter in die Vergangenheit zu gehen. Bei einem Job, der Tagesdaten zusammenstellt, wären 2 Monate wohl zu viel.
                        Aber darauf achten, dass auch ein "stop" angegeben werden muss, sonst holst du die angebrochenen Tage, an welchem der Task läuft mit rein. Steht hier im Thread weiter oben, wie das geht.

                        |> set(key: "_measurement", value: "Hauptzaehler")
                        |> to(bucket: "Stromverbrauch", org: "RBE")
                        das heißt es wird in das bucket Stromverbrauch mit _measurement "Hauptzaehler" geschrieben oder ?

                        genau, ist natürlich frei wählbar.

                        NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

                        Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                        Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                        1 Reply Last reply
                        0
                        • B Offline
                          B Offline
                          bitwicht
                          wrote on last edited by
                          #155

                          @Marc-Berg

                          du meinst so:

                          |> range(start: -2mo, stop: date.truncate(t:-1s, unit:1mo)
                          

                          Jetzt verstehe ich deine Aussage und dann das Problem.

                          Ich wollen mit " stop: now()) " arbeiten und den Task alle 30 Minuten laufen lassen.
                          Dann hätte ich in der Grafana Abfrage auch immer auch den aktuellen Tag mit drin.

                          Dumm aber das ich dann pro Stunde 2 Werte schreibe.

                          So ein Mist, immer ein neues Problem

                          Marc BergM 1 Reply Last reply
                          0
                          • B bitwicht

                            @Marc-Berg

                            du meinst so:

                            |> range(start: -2mo, stop: date.truncate(t:-1s, unit:1mo)
                            

                            Jetzt verstehe ich deine Aussage und dann das Problem.

                            Ich wollen mit " stop: now()) " arbeiten und den Task alle 30 Minuten laufen lassen.
                            Dann hätte ich in der Grafana Abfrage auch immer auch den aktuellen Tag mit drin.

                            Dumm aber das ich dann pro Stunde 2 Werte schreibe.

                            So ein Mist, immer ein neues Problem

                            Marc BergM Online
                            Marc BergM Online
                            Marc Berg
                            Most Active
                            wrote on last edited by
                            #156

                            @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                            |> range(start: -2mo, stop: date.truncate(t:-1s, unit:1mo)

                            in diesem Beispiel würde JETZT (11.01.24 14:00) die Abfrage vom 12.12.23 14:00 bis 01.01.24 00:00 Uhr laufen. Das bedeutet, dass du auch für den Startzeitpunkt mit "truncate" arbeiten musst und statt des Monats den Tag nehmen musst, um ganze Tage bis gestern zu erfassen.

                            |> range(start: date.truncate(t:-3d, unit:1d), stop: date.truncate(t:-1s, unit:1d))
                            

                            das bedeutet JETZT: vom 08.01.24 00:00 Uhr bis 11.01.24 00:00 Uhr

                            NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

                            Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                            Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                            1 Reply Last reply
                            0
                            • B Offline
                              B Offline
                              bitwicht
                              wrote on last edited by
                              #157

                              @Marc Berg

                              OK, baue ich gleich um.
                              In deinem Beispiel ist -3d.

                              Wenn ich das Script jetzt täglich ausführe und heute starte:

                              schreibt er am 11.01
                              Tageswert 11.1
                              Tageswert 10.1
                              Tageswert 09.1

                              schreibt er am 12.01
                              Tageswert 12.1
                              Tageswert 11.1
                              Tageswert 10.1

                              Ist dann der Tageswert vom 10.1, bzw. 11.11 doppelt vorhanden (zwei Einträge in der DB) oder "überschreibt" er den bestehenden?

                              1 Reply Last reply
                              0
                              • B Offline
                                B Offline
                                bitwicht
                                wrote on last edited by bitwicht
                                #158

                                @Marc-Berg

                                Hallo Marc.

                                Ich bin noch immer an dem Umbau und möchte jetzt ein measuremnt das über 100K Einträge hat etwas ausdünnen.

                                Ich arbeiten im Influx Data Explorer.
                                Was passte denn an diesem Syntax nicht?

                                from(bucket: "iobroker-unlimited")
                                    |> range(start: -36mo, stop: -2mo)
                                    |> filter(fn: (r) => r._measurement == "Strom-IR-Haus-Bezug")
                                    |> aggregateWindow(every: 1d, fn: last, timeSrc: "_start")
                                    |> toInt()
                                    |> set(key: "_measurement", value: "TEST-Strom-IR-Haus-Bezug")
                                    |> to(bucket: "iobroker-unlimited")
                                

                                Fehler:

                                 runtime error @5:8-5:15: toInt: failed to evaluate map function: cannot convert string "system.adapter.sonoff.0" to int due to invalid syntax
                                
                                Marc BergM 1 Reply Last reply
                                0
                                • B bitwicht

                                  @Marc-Berg

                                  Hallo Marc.

                                  Ich bin noch immer an dem Umbau und möchte jetzt ein measuremnt das über 100K Einträge hat etwas ausdünnen.

                                  Ich arbeiten im Influx Data Explorer.
                                  Was passte denn an diesem Syntax nicht?

                                  from(bucket: "iobroker-unlimited")
                                      |> range(start: -36mo, stop: -2mo)
                                      |> filter(fn: (r) => r._measurement == "Strom-IR-Haus-Bezug")
                                      |> aggregateWindow(every: 1d, fn: last, timeSrc: "_start")
                                      |> toInt()
                                      |> set(key: "_measurement", value: "TEST-Strom-IR-Haus-Bezug")
                                      |> to(bucket: "iobroker-unlimited")
                                  

                                  Fehler:

                                   runtime error @5:8-5:15: toInt: failed to evaluate map function: cannot convert string "system.adapter.sonoff.0" to int due to invalid syntax
                                  
                                  Marc BergM Online
                                  Marc BergM Online
                                  Marc Berg
                                  Most Active
                                  wrote on last edited by
                                  #159

                                  @bitwicht sagte in Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern:

                                  Was passte denn an diesem Syntax nicht?

                                  Dir fehlt der Filter auf die Spalte "value", sonst bekommst du wahrscheinlich auch die internen Spalten "q" "ack" und "from" mit, wenn die Daten aus dem Adapter kommen.

                                  from(bucket: "iobroker-unlimited")
                                      |> range(start: -36mo, stop: -2mo)
                                      |> filter(fn: (r) => r._measurement == "Strom-IR-Haus-Bezug")
                                      |> filter(fn: (r) => r["_field"] == "value")
                                      |> aggregateWindow(every: 1d, fn: last, timeSrc: "_start")
                                      |> toInt()
                                      |> set(key: "_measurement", value: "TEST-Strom-IR-Haus-Bezug")
                                      |> to(bucket: "iobroker-unlimited")
                                  

                                  NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

                                  Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                                  Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                                  1 Reply Last reply
                                  0
                                  • B Offline
                                    B Offline
                                    bitwicht
                                    wrote on last edited by bitwicht
                                    #160

                                    @Marc-Berg

                                    Er legt mir das neue measurement an, aber wenn ich im Data Explorer bin fehlt bei field "value"

                                    Influx001.PNG

                                    Im Grafana kann ich die Daten aber anzeigen lassen.
                                    Warum fehlen denn im Dataexplorer die Felder ?

                                    Marc BergM 1 Reply Last reply
                                    0
                                    • B bitwicht

                                      @Marc-Berg

                                      Er legt mir das neue measurement an, aber wenn ich im Data Explorer bin fehlt bei field "value"

                                      Influx001.PNG

                                      Im Grafana kann ich die Daten aber anzeigen lassen.
                                      Warum fehlen denn im Dataexplorer die Felder ?

                                      Marc BergM Online
                                      Marc BergM Online
                                      Marc Berg
                                      Most Active
                                      wrote on last edited by
                                      #161

                                      @bitwicht sagte in [Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern]

                                      Warum fehlen denn im Dataexplorer die Felder ?

                                      Wahrscheinlich hast du den Zeitraum nicht groß genug gewählt.

                                      IMG_5888.jpeg

                                      NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+EMQX+Grafana

                                      Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                                      Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                                      1 Reply Last reply
                                      0
                                      • B Offline
                                        B Offline
                                        bitwicht
                                        wrote on last edited by
                                        #162

                                        @Marc-Berg

                                        stimmt :-)

                                        Das heißt ich kopiere jetzt das original-measuremnt in ein measuremnt -TEMP
                                        dann vom TEMP die Dante von XX bis 31.12.2023 aggregiert zurück in das original-measuremnt
                                        und dann von 1.1.2024 bis heute zurück in das original-measuremntdie

                                        ganz schöner Aufwand.

                                        Gibt es nicht ein Befehl der von XX bis YY nur den einen Wert pro Tag stehen lässt und alles andere weghaut ?

                                        1 Reply Last reply
                                        0
                                        • B Offline
                                          B Offline
                                          bitwicht
                                          wrote on last edited by bitwicht
                                          #163

                                          delete.......

                                          1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          612

                                          Online

                                          32.6k

                                          Users

                                          82.3k

                                          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