Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    22
    1
    1.1k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.1k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.4k

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

Geplant Angeheftet Gesperrt Verschoben Off Topic
190 Beiträge 5 Kommentatoren 23.3k Aufrufe 4 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • B bitwicht

    @Marc-Berg

    du meinst so:

    |> range(start: -2mo, stop: date.truncate(t:-1s, unit:1mo)
    

    Jetzt verstehe ich deine Aussage und dann das Problem.

    Ich wollen mit " stop: now()) " arbeiten und den Task alle 30 Minuten laufen lassen.
    Dann hätte ich in der Grafana Abfrage auch immer auch den aktuellen Tag mit drin.

    Dumm aber das ich dann pro Stunde 2 Werte schreibe.

    So ein Mist, immer ein neues Problem

    Marc BergM Offline
    Marc BergM Offline
    Marc Berg
    Most Active
    schrieb am zuletzt editiert von
    #156

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

    |> range(start: -2mo, stop: date.truncate(t:-1s, unit:1mo)

    in diesem Beispiel würde JETZT (11.01.24 14:00) die Abfrage vom 12.12.23 14:00 bis 01.01.24 00:00 Uhr laufen. Das bedeutet, dass du auch für den Startzeitpunkt mit "truncate" arbeiten musst und statt des Monats den Tag nehmen musst, um ganze Tage bis gestern zu erfassen.

    |> range(start: date.truncate(t:-3d, unit:1d), stop: date.truncate(t:-1s, unit:1d))
    

    das bedeutet JETZT: vom 08.01.24 00:00 Uhr bis 11.01.24 00:00 Uhr

    NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+RabbitMQ+Grafana

    Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

    Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

    1 Antwort Letzte Antwort
    0
    • B Offline
      B Offline
      bitwicht
      schrieb am zuletzt editiert von
      #157

      @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 Antwort Letzte Antwort
      0
      • B Offline
        B Offline
        bitwicht
        schrieb am zuletzt editiert von bitwicht
        #158

        @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 BergM 1 Antwort Letzte Antwort
        0
        • B 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 BergM Offline
          Marc BergM Offline
          Marc Berg
          Most Active
          schrieb am zuletzt editiert von
          #159

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

          NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+RabbitMQ+Grafana

          Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

          Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

          1 Antwort Letzte Antwort
          0
          • B Offline
            B Offline
            bitwicht
            schrieb am zuletzt editiert von bitwicht
            #160

            @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 BergM 1 Antwort Letzte Antwort
            0
            • B 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 BergM Offline
              Marc BergM Offline
              Marc Berg
              Most Active
              schrieb am zuletzt editiert von
              #161

              @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

              NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+RabbitMQ+Grafana

              Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

              Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

              1 Antwort Letzte Antwort
              0
              • B Offline
                B Offline
                bitwicht
                schrieb am zuletzt editiert von
                #162

                @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 Antwort Letzte Antwort
                0
                • B Offline
                  B Offline
                  bitwicht
                  schrieb am zuletzt editiert von bitwicht
                  #163

                  delete.......

                  1 Antwort Letzte Antwort
                  0
                  • B Offline
                    B Offline
                    bitwicht
                    schrieb am zuletzt editiert von bitwicht
                    #164

                    deleteeeee

                    1 Antwort Letzte Antwort
                    0
                    • B Offline
                      B Offline
                      bitwicht
                      schrieb am zuletzt editiert von
                      #165

                      @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 BergM 1 Antwort Letzte Antwort
                      0
                      • B bitwicht

                        @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 BergM Offline
                        Marc BergM Offline
                        Marc Berg
                        Most Active
                        schrieb am zuletzt editiert von Marc Berg
                        #166

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

                        NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+RabbitMQ+Grafana

                        Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                        Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                        1 Antwort Letzte Antwort
                        0
                        • B Offline
                          B Offline
                          bitwicht
                          schrieb am zuletzt editiert von bitwicht
                          #167

                          Passt, das wars. Danke.

                          1 Antwort Letzte Antwort
                          0
                          • B Offline
                            B Offline
                            bitwicht
                            schrieb am zuletzt editiert von bitwicht
                            #168

                            @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 Antwort Letzte Antwort
                            0
                            • B Offline
                              B Offline
                              bitwicht
                              schrieb am zuletzt editiert von
                              #169

                              @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 BergM 1 Antwort Letzte Antwort
                              0
                              • B bitwicht

                                @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 BergM Offline
                                Marc BergM Offline
                                Marc Berg
                                Most Active
                                schrieb am zuletzt editiert von
                                #170

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

                                NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+RabbitMQ+Grafana

                                Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                                Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                                1 Antwort Letzte Antwort
                                0
                                • B Offline
                                  B Offline
                                  bitwicht
                                  schrieb am zuletzt editiert von bitwicht
                                  #171

                                  @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 BergM 1 Antwort Letzte Antwort
                                  0
                                  • B 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 BergM Offline
                                    Marc BergM Offline
                                    Marc Berg
                                    Most Active
                                    schrieb am zuletzt editiert von
                                    #172

                                    @bitwicht

                                    zeig mal die Abfrage:

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

                                    NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+RabbitMQ+Grafana

                                    Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                                    Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                                    1 Antwort Letzte Antwort
                                    0
                                    • B Offline
                                      B Offline
                                      bitwicht
                                      schrieb am zuletzt editiert von
                                      #173

                                      @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 BergM 1 Antwort Letzte Antwort
                                      0
                                      • B bitwicht

                                        @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 BergM Offline
                                        Marc BergM Offline
                                        Marc Berg
                                        Most Active
                                        schrieb am zuletzt editiert von
                                        #174

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

                                        NUC10I3+Ubuntu+Docker+ioBroker+influxDB2+Node Red+RabbitMQ+Grafana

                                        Pi-hole, Traefik, Checkmk, Conbee II+Zigbee2MQTT, ESPSomfy-RTS, LoRaWAN, Arduino, KiCad

                                        Benutzt das Voting im Beitrag, wenn er euch geholfen hat.

                                        1 Antwort Letzte Antwort
                                        0
                                        • B Offline
                                          B Offline
                                          bitwicht
                                          schrieb am zuletzt editiert von
                                          #175

                                          @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 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          794

                                          Online

                                          32.5k

                                          Benutzer

                                          81.6k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe