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
    3.2k

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.4k

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

Scheduled Pinned Locked Moved Off Topic
190 Posts 5 Posters 24.9k 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
    #177

    @Marc-Berg

    Hallo Marc.

    Ich spiele gerade mit dem Adapter Device-Reminder.

    Er schreibt folgende Werte:

    Time                    value
    2024-03-07 13:02:23     [{"start":"07.03.2024 11:00:32","end":"07.03.2024 13:02:23","runtime":"02:01:40"}]
    

    Kann ich das als Bar Chart im Grafana verwerten?

    ZB:
    Balken, summiert, Anzahl, pro Tag / Monat / Jahr.
    Ein Balken pro Datum mit der Länge der Laufzeit.

    Geht das? Hast du zufällig ein Beispiel?

    Marc BergM 1 Reply Last reply
    0
    • B bitwicht

      @Marc-Berg

      Hallo Marc.

      Ich spiele gerade mit dem Adapter Device-Reminder.

      Er schreibt folgende Werte:

      Time                    value
      2024-03-07 13:02:23     [{"start":"07.03.2024 11:00:32","end":"07.03.2024 13:02:23","runtime":"02:01:40"}]
      

      Kann ich das als Bar Chart im Grafana verwerten?

      ZB:
      Balken, summiert, Anzahl, pro Tag / Monat / Jahr.
      Ein Balken pro Datum mit der Länge der Laufzeit.

      Geht das? Hast du zufällig ein Beispiel?

      Marc BergM Offline
      Marc BergM Offline
      Marc Berg
      Most Active
      wrote on last edited by
      #178

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

      Geht das? Hast du zufällig ein Beispiel?

      Habe ich noch nie gemacht, und müsste selbst suchen.

      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
        #179

        @Marc-Berg

        Wenn ich im iobroker im Verlauf schaue, schaut es so aus:

        Snip1.png

        Wenn ich in der Influx eine Abfrage mache kommt bei "value" ein Fehler und "q" nix brauchbares:
        Snip2.png
        Snip3.png

        Wir der Wert nicht als Zahl sondern als Text gespeichert oder was passiert denn da ?

        Marc BergM 1 Reply Last reply
        0
        • B bitwicht

          @Marc-Berg

          Wenn ich im iobroker im Verlauf schaue, schaut es so aus:

          Snip1.png

          Wenn ich in der Influx eine Abfrage mache kommt bei "value" ein Fehler und "q" nix brauchbares:
          Snip2.png
          Snip3.png

          Wir der Wert nicht als Zahl sondern als Text gespeichert oder was passiert denn da ?

          Marc BergM Offline
          Marc BergM Offline
          Marc Berg
          Most Active
          wrote on last edited by
          #180

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

          Wenn ich in der Influx eine Abfrage mache kommt bei "value" ein Fehler und "q" nix brauchbares:

          Da den Wert "01:37:10" nicht als Number gespeichert werden kann, wird es ein String sein. Strings lassen sich nicht mit der "aggregate"-Funktion bearbeiten, deshalb die Fehlermeldung, die du allerdings weg bekommst, wenn du das "aggregate" abschaltest (unten rechts -->"custom" --> Haken wegnehmen)

          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
            #181

            @Marc-Berg

            Dann bin ich einen Schritt weiter:
            Snip4.png

            Die Werte stehen in: _value

            Müsste ich dann im Grafana auf _valie gehen - sowas

            from(bucket: "iobroker_unlimited")
              |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
              |> filter(fn: (r) => r["_measurement"] == "Geraetestatus-Trockner-LetzteLaufzeit")
              |> filter(fn: (r) => r["_field"] == "_value")
             // |> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
              |> yield(name: "mean")
            
            Marc BergM 1 Reply Last reply
            0
            • B bitwicht

              @Marc-Berg

              Dann bin ich einen Schritt weiter:
              Snip4.png

              Die Werte stehen in: _value

              Müsste ich dann im Grafana auf _valie gehen - sowas

              from(bucket: "iobroker_unlimited")
                |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
                |> filter(fn: (r) => r["_measurement"] == "Geraetestatus-Trockner-LetzteLaufzeit")
                |> filter(fn: (r) => r["_field"] == "_value")
               // |> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
                |> yield(name: "mean")
              
              Marc BergM Offline
              Marc BergM Offline
              Marc Berg
              Most Active
              wrote on last edited by
              #182

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

              |> filter(fn: (r) => r["_field"] == "_value")

              Die Werte stehen in der Spalte"_value". Was du aber machen willst, ist die Datensätze selektieren, in denen das Feld "value" heißt. Also:

              |> filter(fn: (r) => r["_field"] == "value")
              

              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
                #183

                @Marc-Berg

                Im Grafana sagt er dann "No Data" oder "Data is missing a number field"

                Ich würde gerne folgende Auswertung bauen:

                Snip5.png

                1. Mit bar gauge die Laufzeit am jeweiligen Tag
                2. Mit bar chart die Anzahl im Monat

                Wie bringe ich es ihm denn bei das er bar gauge einfach den Zeitstempel und Leufzeit nehmen muss und bei bar chart die Anzahl der Einträge in einem Monat summiert ?

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

                  @bitwicht

                  Du musst die Zeiten als Number (z.B: Anzahl der Minuten) speichern. Dann kannst du diese Daten in Flux auch sinnvoll summieren. Zur Darstellung im Format "hh:mi" musst du die Daten in Grafana formatieren. Das war hier vor ein paar Wochen/Monaten schon mal Thema, finde ich aber gerade nicht.

                  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
                    #185

                    deldeldel

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

                      @Marc-Berg

                      Ich habe mit diesen neuen Datenpunkt angelegt:

                      createState("javascript.0.device-reminder.Waschmaschine.runtime_counter", 0, {type: 'number', read: true, write: false, role: 'value'});
                      
                      

                      Ich lasse in den Datenpunkt nur 0 oder 1 schreiben.

                      Im Grafana möchte ich dann nur alle Zahlen Addieren:

                      import "timezone"
                      option location = timezone.location(name: "Europe/Berlin")
                      
                      from(bucket: "iobroker_unlimited")
                        |> range(start: -15d)
                        |> filter(fn: (r) => r["_measurement"] == "Geraetenutzung_Trockner_counter")
                        |> aggregateWindow(every: 1d, fn: sum, timeSrc: "_start")
                        |> yield(name: "mean")
                      
                      

                      Es kommt aber der Fehler:
                      invalid: runtime error: unsupported aggregate column type bool

                      Ich habe doch eine "number" angelegt ?!

                      Marc BergM 1 Reply Last reply
                      0
                      • B bitwicht

                        @Marc-Berg

                        Ich habe mit diesen neuen Datenpunkt angelegt:

                        createState("javascript.0.device-reminder.Waschmaschine.runtime_counter", 0, {type: 'number', read: true, write: false, role: 'value'});
                        
                        

                        Ich lasse in den Datenpunkt nur 0 oder 1 schreiben.

                        Im Grafana möchte ich dann nur alle Zahlen Addieren:

                        import "timezone"
                        option location = timezone.location(name: "Europe/Berlin")
                        
                        from(bucket: "iobroker_unlimited")
                          |> range(start: -15d)
                          |> filter(fn: (r) => r["_measurement"] == "Geraetenutzung_Trockner_counter")
                          |> aggregateWindow(every: 1d, fn: sum, timeSrc: "_start")
                          |> yield(name: "mean")
                        
                        

                        Es kommt aber der Fehler:
                        invalid: runtime error: unsupported aggregate column type bool

                        Ich habe doch eine "number" angelegt ?!

                        Marc BergM Offline
                        Marc BergM Offline
                        Marc Berg
                        Most Active
                        wrote on last edited by
                        #187

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

                        invalid: runtime error: unsupported aggregate column type bool

                        Dir fehlt der Filter, wie hier

                        https://forum.iobroker.net/post/1137716

                        geschrieben.

                        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
                          #188

                          @Marc-Berg

                          Hi Marc.

                          ich hatte folgende Anfrage die eigentlich gelaufen ist:

                          import "timezone"
                          option location = timezone.location(name: "Europe/Berlin")
                          
                          Z1=
                          from(bucket: "iobroker_unlimited")
                            |> range(start: -24mo)
                            |> filter(fn: (r) => r["_measurement"] == "Wasserzaehler-CAM-Haus")
                            |> filter(fn: (r) => r["_field"] == "value")
                            |> difference()
                            |> aggregateWindow(every: 1mo, fn: sum, createEmpty: false, timeSrc: "_start")
                            |> keep(columns: ["_value", "_time"])
                           
                            Z2=
                          from(bucket: "iobroker_unlimited")
                            |> range(start: -24mo)
                            |> filter(fn: (r) => r["_measurement"] == "Wasserzaehler-CAM-Garten")
                            |> filter(fn: (r) => r["_field"] == "value")
                            |> difference()
                            |> aggregateWindow(every: 1mo, fn: sum, createEmpty: false, timeSrc: "_start")
                          
                            join(tables: {Z1: Z1, Z2: Z2}, on: ["_time"])
                            |>map(fn: (r) => ({_time: r._time, Wasser_Haus: r._value_Z1-r._value_Z2}))
                          
                          

                          Habe heute meinen PI neu gestartet und jetzt kommt folgender Fehler:

                          internal error: panic: runtime error: invalid memory address or nil pointer dereference
                          

                          Weisst du warum?

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

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

                            Weisst du warum?

                            Nein, keine Ahnung. Ich müsste auch Google befragen.

                            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
                              #190

                              @Marc-Berg

                              Ein Zeitraum von -6mo geht, bei -12mo kommt der Fehler.

                              Wenn ich den dem measuremnt alle Daten älter als 6 Monate lösche, geht es wieder.

                              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

                              647

                              Online

                              32.7k

                              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