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.0k

  • 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 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

                            370

                            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