Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Off Topic
    4. Ertrag (Tag, Monat, Jahr) berechnen und in Datei speichern

    NEWS

    • Monatsrückblick - April 2025

    • Minor js-controller 7.0.7 Update in latest repo

    • Save The Date: ioBroker@Smart Living Forum Solingen, 14.06.

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

    This topic has been deleted. Only users with topic management privileges can see it.
    • B
      bitwicht last edited by bitwicht

      Passt, das wars. Danke.

      1 Reply Last reply Reply Quote 0
      • B
        bitwicht last edited by bitwicht

        @Marc-Berg

        Ich habe die Daten (ca. 12 Monate) dann so eingegeben ohne Problem:

        PV_SE_Erzeugung_Monat_Adapter value=374000 1706740200
        

        Nach weiterer Eingabe von ca. 12 Monaten kommt jetzt dieser Fehler:

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

        Ich habe jetzt das komplette measuremnt gelöscht und neu angelegt, jetzt scheint es zu gehen

        1 Reply Last reply Reply Quote 0
        • B
          bitwicht last edited by

          @Marc-Berg

          Hast du hier noch eine Idee:

          Ich gebe diesen Unix Zeit ein:

          1669761000
          

          Das ist laut Rechner der: Your Time Zone Tue Nov 29 2022 23:30:00 GMT+0100 (Mitteleuropäische Normalzeit)

          In der Influx wird es aber als

          2022-12-02T20:48:00.000Z
          

          eingetragen

          Marc Berg 1 Reply Last reply Reply Quote 0
          • Marc Berg
            Marc Berg Most Active @bitwicht last edited by

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

            Hast du hier noch eine Idee:

            Ich kann mir jetzt nicht vorstellen, dass die InfluxDB aus diesem Timestamp ein falsches Datum macht.
            Und aus diesen zwei "Schnipseln" ist das für mich auch nicht wirklich "beweisbar".

            1 Reply Last reply Reply Quote 0
            • B
              bitwicht last edited by bitwicht

              @Marc-Berg

              hier mein Import:

              PV_SE_Erzeugung_Jahr_Adapter value=21300000 1703975400 (30.12.2023)
              PV_SE_Erzeugung_Jahr_Adapter value=23200000 1672439400 (30.12.2022)
              PV_SE_Erzeugung_Jahr_Adapter value=21800000 1640903400 (30.12.2021)
              

              und was dann in der DB steht:
              Screenshot 2024-02-16 112903.png

              Die Zeit auf dem System passt:

              Fri 16 Feb 11:34:52 CET 2024
              
              
              Marc Berg 1 Reply Last reply Reply Quote 0
              • Marc Berg
                Marc Berg Most Active @bitwicht last edited by

                @bitwicht

                zeig mal die Abfrage:

                b407b599-7bac-49cd-a231-68038833ce91-grafik.png

                1 Reply Last reply Reply Quote 0
                • B
                  bitwicht last edited by

                  @Marc-Berg

                  from(bucket: "iobroker_unlimited")
                    |> range(start: v.timeRangeStart, stop: v.timeRangeStop)
                    |> filter(fn: (r) => r["_measurement"] == "PV_SE_Erzeugung_Jahr_Adapter")
                    |> filter(fn: (r) => r["_field"] == "value")
                    |> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)
                    |> yield(name: "mean")
                  

                  Ohne

                                  import "timezone" 
                                  option location = timezone.location(name: "Europe/Berlin") 
                  
                  Marc Berg 1 Reply Last reply Reply Quote 0
                  • Marc Berg
                    Marc Berg Most Active @bitwicht last edited by

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

                    |> aggregateWindow(every: v.windowPeriod, fn: mean, createEmpty: false)

                    diese Zeile rausnehmen. Damit werden doch andere Zeitfenster gebildet.

                    1 Reply Last reply Reply Quote 0
                    • B
                      bitwicht last edited by

                      @Marc-Berg
                      Danke.
                      Ich habe im Dataexplorer nur die Häkchen gesetzt und auf Submit geklickt.
                      Dann kommt automatisch die Abfrage. Ich dachte da zeit er einfach an was in der Tabelle value ist.

                      1 Reply Last reply Reply Quote 0
                      • B
                        bitwicht last edited by bitwicht

                        delete xxx

                        1 Reply Last reply Reply Quote 0
                        • B
                          bitwicht last edited by

                          @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 Berg 1 Reply Last reply Reply Quote 0
                          • Marc Berg
                            Marc Berg Most Active @bitwicht last edited by

                            @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.

                            1 Reply Last reply Reply Quote 0
                            • B
                              bitwicht last edited by

                              @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 Berg 1 Reply Last reply Reply Quote 0
                              • Marc Berg
                                Marc Berg Most Active @bitwicht last edited by

                                @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)

                                1 Reply Last reply Reply Quote 0
                                • B
                                  bitwicht last edited by

                                  @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 Berg 1 Reply Last reply Reply Quote 0
                                  • Marc Berg
                                    Marc Berg Most Active @bitwicht last edited by

                                    @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")
                                    
                                    1 Reply Last reply Reply Quote 0
                                    • B
                                      bitwicht last edited by

                                      @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 Reply Quote 0
                                      • Marc Berg
                                        Marc Berg Most Active last edited by

                                        @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.

                                        1 Reply Last reply Reply Quote 0
                                        • B
                                          bitwicht last edited by bitwicht

                                          deldeldel

                                          1 Reply Last reply Reply Quote 0
                                          • B
                                            bitwicht last edited by

                                            @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 Berg 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            1.0k
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            190
                                            12730
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo