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

      @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 Reply Quote 0
      • B
        bitwicht last edited by 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 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:

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

              Warum fehlen denn im Dataexplorer die Felder ?

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

              IMG_5888.jpeg

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

                @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 Reply Quote 0
                • B
                  bitwicht last edited by bitwicht

                  delete.......

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

                    deleteeeee

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

                      @Marc-Berg

                      Ich versuche jetzt gerade in das neu angelegte Bucket die Historischen Werte einzutragen (was im alten Bucket nicht ging).

                      Manueller Import
                      Einstellung: Sekunden

                      PV_SE_Erzeugung_Monat_Adapter value="374000" 1706740200
                      

                      Wenn ich dann eine Abfrage auf das Measuremnt mache um wir die Werte anzeigen zu lassen kommt immer der Fehler:

                      unsupported input type for mean aggregate: string
                      

                      Was mache ich denn beim Import falsch?

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

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

                        Was mache ich denn beim Import falsch?

                        Du wirst in deiner (wahrscheinlich automatisch erstellen) Abfrage ein "aggregateWindow" drin haben, was auf einer Spalte, die nicht vom Typ "number" ist, nicht funktioniert. Wenn du den Wert in " setzt, wird daraus automatisch ein String.

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            990
                                            Online

                                            31.6k
                                            Users

                                            79.4k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            190
                                            12770
                                            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