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

  • 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.8k 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

    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 Online
    Marc BergM Online
    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 Online
        Marc BergM Online
        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 Online
            Marc BergM Online
            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 Online
                  Marc BergM Online
                  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 Online
                      Marc BergM Online
                      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

                        596

                        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