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. Skripten / Logik
  4. JavaScript
  5. JavaScript zum Auslesen der Tibber API?

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    2.1k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    16
    1
    2.8k

JavaScript zum Auslesen der Tibber API?

Geplant Angeheftet Gesperrt Verschoben JavaScript
51 Beiträge 10 Kommentatoren 7.8k Aufrufe 7 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.
  • S skorpil

    @oliverio Sorry, es war die Home ID. Du hast recht

    OliverIOO Offline
    OliverIOO Offline
    OliverIO
    schrieb am zuletzt editiert von
    #28

    @skorpil
    dann ist sie falsch oder du bist nicht authentifiziert

    Meine Adapter und Widgets
    TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
    Links im Profil

    S 1 Antwort Letzte Antwort
    0
    • mickymM mickym

      Tja vielleicht ist NodeRed doch nicht so kompliziert. ;) und scheint zu funktionieren. ;)

      S Offline
      S Offline
      skorpil
      schrieb am zuletzt editiert von
      #29

      @mickym da dürftest Du recht haben. Ich hatte gehofft, es gäbe auch einen direkten Weg. Ich werde das morgen in Angriff nehmen.

      mickymM 1 Antwort Letzte Antwort
      0
      • OliverIOO OliverIO

        @skorpil
        dann ist sie falsch oder du bist nicht authentifiziert

        S Offline
        S Offline
        skorpil
        schrieb am zuletzt editiert von
        #30

        @oliverio ich glaubte, sie sei richtig. Heute Abend kann ich das nicht mehr prüfen. Ich gebe morgen Feedback. Danke dennoch schon Mal

        OliverIOO 1 Antwort Letzte Antwort
        0
        • S skorpil

          @oliverio ich glaubte, sie sei richtig. Heute Abend kann ich das nicht mehr prüfen. Ich gebe morgen Feedback. Danke dennoch schon Mal

          OliverIOO Offline
          OliverIOO Offline
          OliverIO
          schrieb am zuletzt editiert von
          #31

          @skorpil
          probiere erst mal den weg über node red.
          wenn der funktioniert und alle parameter richtig sind, dann kann man nochmal schauen, wie man das auf javascript überträgt

          Meine Adapter und Widgets
          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
          Links im Profil

          S 1 Antwort Letzte Antwort
          0
          • OliverIOO OliverIO

            @skorpil
            probiere erst mal den weg über node red.
            wenn der funktioniert und alle parameter richtig sind, dann kann man nochmal schauen, wie man das auf javascript überträgt

            S Offline
            S Offline
            skorpil
            schrieb am zuletzt editiert von
            #32

            @oliverio das mache ich! Gerade habe ich nochmal die homeID und den Token hier

            https://developer.tibber.com/explorer
            

            überprüft! Sie sind beide richtig. Ergo stimmt irgendwas am Aufruf nicht. Aber nach meiner Prüfung über NodeRed wissen wir morgen mehr. Danke nochmals

            1 Antwort Letzte Antwort
            0
            • S skorpil

              @mickym da dürftest Du recht haben. Ich hatte gehofft, es gäbe auch einen direkten Weg. Ich werde das morgen in Angriff nehmen.

              mickymM Online
              mickymM Online
              mickym
              Most Active
              schrieb am zuletzt editiert von mickym
              #33

              @skorpil sagte in JavaScript zum Auslesen der Tibber API?:

              @mickym da dürftest Du recht haben. Ich hatte gehofft, es gäbe auch einen direkten Weg. Ich werde das morgen in Angriff nehmen.

              Was ist denn an NodeRed bitte indirekt. NodeRed ist unter dem iobroker (bis auf ein paar Kleinigkeiten) den anderen Logikmaschinen wie Javascript oder Blockly gleichwertig. Gerade wenn es im iobroker keinen passenden Adapter gibt, hat man mit den NodeRed Nodes die Möglichkeit den iobroker zu erweitern (zudem die NodeRed Community einiges größer ist). Die Kommunikation ist also genauso direkt - kein bisschen indirekter oder weniger performant. Für mich sieht das immer wieder so aus, als ob man sich mit Händen und Füssen wehrt sich mit diesem tollen Tool zu beschäftigen und lieber Javascript codiert, was übrigens mit NodeRed auch geht.

              Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

              S 1 Antwort Letzte Antwort
              1
              • mickymM mickym

                @skorpil sagte in JavaScript zum Auslesen der Tibber API?:

                @mickym da dürftest Du recht haben. Ich hatte gehofft, es gäbe auch einen direkten Weg. Ich werde das morgen in Angriff nehmen.

                Was ist denn an NodeRed bitte indirekt. NodeRed ist unter dem iobroker (bis auf ein paar Kleinigkeiten) den anderen Logikmaschinen wie Javascript oder Blockly gleichwertig. Gerade wenn es im iobroker keinen passenden Adapter gibt, hat man mit den NodeRed Nodes die Möglichkeit den iobroker zu erweitern (zudem die NodeRed Community einiges größer ist). Die Kommunikation ist also genauso direkt - kein bisschen indirekter oder weniger performant. Für mich sieht das immer wieder so aus, als ob man sich mit Händen und Füssen wehrt sich mit diesem tollen Tool zu beschäftigen und lieber Javascript codiert, was übrigens mit NodeRed auch geht.

                S Offline
                S Offline
                skorpil
                schrieb am zuletzt editiert von
                #34

                @mickym alles gut! Ich habe mich damit nur noch nie beschäftigt. Ich wollte halt nicht noch ein weiteres System lernen, wo ich JavaScript noch nicht einmal beherrsche. Daher schien es mir ein Umweg zu sein. Ich lasse mich ja gerne eines Besseren belehren. Und morgen starte ich dann also mit NodeRed.

                1 Antwort Letzte Antwort
                0
                • S Offline
                  S Offline
                  skorpil
                  schrieb am zuletzt editiert von
                  #35

                  mit node red hat es geklappt. Tolle Anleitung. Auch wenn ich keine Ahnung habe, was ich da genau gemacht habe, es funktioniert.

                  mickymM 1 Antwort Letzte Antwort
                  0
                  • S skorpil

                    mit node red hat es geklappt. Tolle Anleitung. Auch wenn ich keine Ahnung habe, was ich da genau gemacht habe, es funktioniert.

                    mickymM Online
                    mickymM Online
                    mickym
                    Most Active
                    schrieb am zuletzt editiert von
                    #36

                    @skorpil sagte in JavaScript zum Auslesen der Tibber API?:

                    Auch wenn ich keine Ahnung habe, was ich da genau gemacht habe, es funktioniert.

                    Vielleicht wäre das ja mal ein Grund sich mit diesem tollen Tool näher zu beschäftigen. ;)

                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                    O 1 Antwort Letzte Antwort
                    0
                    • mickymM mickym

                      @skorpil sagte in JavaScript zum Auslesen der Tibber API?:

                      Auch wenn ich keine Ahnung habe, was ich da genau gemacht habe, es funktioniert.

                      Vielleicht wäre das ja mal ein Grund sich mit diesem tollen Tool näher zu beschäftigen. ;)

                      O Offline
                      O Offline
                      ostseeskipper
                      schrieb am zuletzt editiert von
                      #37

                      Hinweis
                      Unter Github gibts eine funktionierende JS Version um die Tibber API auszulesen. Lediglich der Public Token muss aktualisiert werden
                      zum Script

                      paul53P 1 Antwort Letzte Antwort
                      2
                      • O ostseeskipper

                        Hinweis
                        Unter Github gibts eine funktionierende JS Version um die Tibber API auszulesen. Lediglich der Public Token muss aktualisiert werden
                        zum Script

                        paul53P Offline
                        paul53P Offline
                        paul53
                        schrieb am zuletzt editiert von paul53
                        #38

                        @ostseeskipper sagte: funktionierende JS Version um die Tibber API auszulesen.

                        Habe ein paar Anpassungen und Korrekturen vorgenommen:

                        // Get Tibber Data  (Awattar alternative)
                        const url = 'https://api.tibber.com/v1-beta/gql';
                        const token = "Bearer 5K4MVS-OjfWhK_4yrjOlFe1F6kJXPVf7eQYggo8ebAE"; // Anpassen!
                        const path = '0_userdata.0.Tibber.Preise.'; // Anpassen!
                        
                        function requestData() {
                            const options = {
                                uri: url,
                                method: 'POST',
                                body: '{"query": "{ viewer { homes { currentSubscription{ priceInfo{ today{ total startsAt } tomorrow{ total startsAt } } } } } }" }',
                                headers: {
                                    'Authorization': token,
                                    'Content-Type': 'application/json'
                                }
                            }
                         
                            request(options, (error, response, body) => {
                                if(error) return log(error, 'warn');
                         
                                if(response.statusCode == 200) {
                                    let array = JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.today
                                        array = array.concat(JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.tomorrow)
                                    var jetzt = new Date(),
                                        midn = new Date(
                                            jetzt.getFullYear(),
                                            jetzt.getMonth(),
                                            jetzt.getDate(),
                                            0,0,0),
                                        diffhr = Math.floor((jetzt.getTime() - midn.getTime())/3600000);
                                    for(let i = diffhr; i < array.length; i++) {
                                        let a = i - diffhr
                                        let stateBaseName = path + a + ".";
                                        let start = new Date(Date.parse(array[i].startsAt));
                                        let option = { hour12: false, hour: '2-digit', minute:'2-digit'};
                                        let startTime = start.toLocaleTimeString('de-DE', option);
                                        let startDate = start.toLocaleDateString('de-DE');
                                         
                                        let end = new Date(Date.parse(array[i].startsAt)).getTime()+3600000
                                        let endTime = new Date(end).toLocaleTimeString('de-DE', option);
                                        let price = 100 * array[i].total;
                                        //console.log(startTime + ',' + startDate + ',' + startTime + ',' + endTime + ',' + price )
                                        
                                        if(existsState(stateBaseName + "startTime")) setState(stateBaseName + "startTime", startTime, true);
                                        else createState(stateBaseName + "startTime", startTime, {
                                            read: true,
                                            write: false,
                                            name: "Gultigkeitsbeginn (Uhrzeit)",
                                            type: "string",
                                            def: ''
                                        });
                        
                                        if(existsState(stateBaseName + "startDate")) setState(stateBaseName + "startDate", startDate, true);
                                        else createState(stateBaseName + "startDate", startDate, {
                                            read: true,
                                            write: false,
                                            name: "Gultigkeitsbeginn (Datum)",
                                            type: "string",
                                            def: ''
                                        });
                        
                                        if(existsState(stateBaseName + "endTime")) setState(stateBaseName + "endTime", endTime, true);
                                        else createState(stateBaseName + "endTime", endTime, {
                                            read: true,
                                            write: false,
                                            name: "Gultigkeitsende (Uhrzeit)",
                                            type: "string",
                                            def: ''
                                        });
                        
                                        if(existsState(stateBaseName + "price")) setState(stateBaseName + "price", price, true);
                                        else createState(stateBaseName + "price", price, {
                                            read: true,
                                            write: false,
                                            name: "Preis",
                                            type: "number",
                                            unit: 'ct/kWh',
                                            def: 0
                                        });
                                    };
                                };
                            });
                        }
                        
                        requestData();
                        schedule("0 * * * *", requestData);
                        

                        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                        Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                        crunchipC O 2 Antworten Letzte Antwort
                        2
                        • paul53P paul53

                          @ostseeskipper sagte: funktionierende JS Version um die Tibber API auszulesen.

                          Habe ein paar Anpassungen und Korrekturen vorgenommen:

                          // Get Tibber Data  (Awattar alternative)
                          const url = 'https://api.tibber.com/v1-beta/gql';
                          const token = "Bearer 5K4MVS-OjfWhK_4yrjOlFe1F6kJXPVf7eQYggo8ebAE"; // Anpassen!
                          const path = '0_userdata.0.Tibber.Preise.'; // Anpassen!
                          
                          function requestData() {
                              const options = {
                                  uri: url,
                                  method: 'POST',
                                  body: '{"query": "{ viewer { homes { currentSubscription{ priceInfo{ today{ total startsAt } tomorrow{ total startsAt } } } } } }" }',
                                  headers: {
                                      'Authorization': token,
                                      'Content-Type': 'application/json'
                                  }
                              }
                           
                              request(options, (error, response, body) => {
                                  if(error) return log(error, 'warn');
                           
                                  if(response.statusCode == 200) {
                                      let array = JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.today
                                          array = array.concat(JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.tomorrow)
                                      var jetzt = new Date(),
                                          midn = new Date(
                                              jetzt.getFullYear(),
                                              jetzt.getMonth(),
                                              jetzt.getDate(),
                                              0,0,0),
                                          diffhr = Math.floor((jetzt.getTime() - midn.getTime())/3600000);
                                      for(let i = diffhr; i < array.length; i++) {
                                          let a = i - diffhr
                                          let stateBaseName = path + a + ".";
                                          let start = new Date(Date.parse(array[i].startsAt));
                                          let option = { hour12: false, hour: '2-digit', minute:'2-digit'};
                                          let startTime = start.toLocaleTimeString('de-DE', option);
                                          let startDate = start.toLocaleDateString('de-DE');
                                           
                                          let end = new Date(Date.parse(array[i].startsAt)).getTime()+3600000
                                          let endTime = new Date(end).toLocaleTimeString('de-DE', option);
                                          let price = 100 * array[i].total;
                                          //console.log(startTime + ',' + startDate + ',' + startTime + ',' + endTime + ',' + price )
                                          
                                          if(existsState(stateBaseName + "startTime")) setState(stateBaseName + "startTime", startTime, true);
                                          else createState(stateBaseName + "startTime", startTime, {
                                              read: true,
                                              write: false,
                                              name: "Gultigkeitsbeginn (Uhrzeit)",
                                              type: "string",
                                              def: ''
                                          });
                          
                                          if(existsState(stateBaseName + "startDate")) setState(stateBaseName + "startDate", startDate, true);
                                          else createState(stateBaseName + "startDate", startDate, {
                                              read: true,
                                              write: false,
                                              name: "Gultigkeitsbeginn (Datum)",
                                              type: "string",
                                              def: ''
                                          });
                          
                                          if(existsState(stateBaseName + "endTime")) setState(stateBaseName + "endTime", endTime, true);
                                          else createState(stateBaseName + "endTime", endTime, {
                                              read: true,
                                              write: false,
                                              name: "Gultigkeitsende (Uhrzeit)",
                                              type: "string",
                                              def: ''
                                          });
                          
                                          if(existsState(stateBaseName + "price")) setState(stateBaseName + "price", price, true);
                                          else createState(stateBaseName + "price", price, {
                                              read: true,
                                              write: false,
                                              name: "Preis",
                                              type: "number",
                                              unit: 'ct/kWh',
                                              def: 0
                                          });
                                      };
                                  };
                              });
                          }
                          
                          requestData();
                          schedule("0 * * * *", requestData);
                          
                          crunchipC Abwesend
                          crunchipC Abwesend
                          crunchip
                          Forum Testing Most Active
                          schrieb am zuletzt editiert von
                          #39

                          @paul53 Daten kommen an

                          umgestiegen von Proxmox auf Unraid

                          1 Antwort Letzte Antwort
                          1
                          • paul53P paul53

                            @ostseeskipper sagte: funktionierende JS Version um die Tibber API auszulesen.

                            Habe ein paar Anpassungen und Korrekturen vorgenommen:

                            // Get Tibber Data  (Awattar alternative)
                            const url = 'https://api.tibber.com/v1-beta/gql';
                            const token = "Bearer 5K4MVS-OjfWhK_4yrjOlFe1F6kJXPVf7eQYggo8ebAE"; // Anpassen!
                            const path = '0_userdata.0.Tibber.Preise.'; // Anpassen!
                            
                            function requestData() {
                                const options = {
                                    uri: url,
                                    method: 'POST',
                                    body: '{"query": "{ viewer { homes { currentSubscription{ priceInfo{ today{ total startsAt } tomorrow{ total startsAt } } } } } }" }',
                                    headers: {
                                        'Authorization': token,
                                        'Content-Type': 'application/json'
                                    }
                                }
                             
                                request(options, (error, response, body) => {
                                    if(error) return log(error, 'warn');
                             
                                    if(response.statusCode == 200) {
                                        let array = JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.today
                                            array = array.concat(JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.tomorrow)
                                        var jetzt = new Date(),
                                            midn = new Date(
                                                jetzt.getFullYear(),
                                                jetzt.getMonth(),
                                                jetzt.getDate(),
                                                0,0,0),
                                            diffhr = Math.floor((jetzt.getTime() - midn.getTime())/3600000);
                                        for(let i = diffhr; i < array.length; i++) {
                                            let a = i - diffhr
                                            let stateBaseName = path + a + ".";
                                            let start = new Date(Date.parse(array[i].startsAt));
                                            let option = { hour12: false, hour: '2-digit', minute:'2-digit'};
                                            let startTime = start.toLocaleTimeString('de-DE', option);
                                            let startDate = start.toLocaleDateString('de-DE');
                                             
                                            let end = new Date(Date.parse(array[i].startsAt)).getTime()+3600000
                                            let endTime = new Date(end).toLocaleTimeString('de-DE', option);
                                            let price = 100 * array[i].total;
                                            //console.log(startTime + ',' + startDate + ',' + startTime + ',' + endTime + ',' + price )
                                            
                                            if(existsState(stateBaseName + "startTime")) setState(stateBaseName + "startTime", startTime, true);
                                            else createState(stateBaseName + "startTime", startTime, {
                                                read: true,
                                                write: false,
                                                name: "Gultigkeitsbeginn (Uhrzeit)",
                                                type: "string",
                                                def: ''
                                            });
                            
                                            if(existsState(stateBaseName + "startDate")) setState(stateBaseName + "startDate", startDate, true);
                                            else createState(stateBaseName + "startDate", startDate, {
                                                read: true,
                                                write: false,
                                                name: "Gultigkeitsbeginn (Datum)",
                                                type: "string",
                                                def: ''
                                            });
                            
                                            if(existsState(stateBaseName + "endTime")) setState(stateBaseName + "endTime", endTime, true);
                                            else createState(stateBaseName + "endTime", endTime, {
                                                read: true,
                                                write: false,
                                                name: "Gultigkeitsende (Uhrzeit)",
                                                type: "string",
                                                def: ''
                                            });
                            
                                            if(existsState(stateBaseName + "price")) setState(stateBaseName + "price", price, true);
                                            else createState(stateBaseName + "price", price, {
                                                read: true,
                                                write: false,
                                                name: "Preis",
                                                type: "number",
                                                unit: 'ct/kWh',
                                                def: 0
                                            });
                                        };
                                    };
                                });
                            }
                            
                            requestData();
                            schedule("0 * * * *", requestData);
                            
                            O Offline
                            O Offline
                            ostseeskipper
                            schrieb am zuletzt editiert von
                            #40

                            @paul53
                            Das Script ist war ne gute Basis und dafür das es aus 2020 ist ne gute Arbeit.

                            Mir gefiel einiges nicht daran und bin noch am probieren und testen.
                            Unter anderen, das Datenpunkt anlegen ohne if(exitsState) was du nun schon geändert hast.

                            Habe auch lange gerätselt wozu das hier ist.

                                        var jetzt = new Date(),
                            
                                            midn = new Date(
                            
                                                jetzt.getFullYear(),
                            
                                                jetzt.getMonth(),
                            
                                                jetzt.getDate(),
                            
                                                0,0,0),
                            
                                            diffhr = Math.floor((jetzt.getTime() - midn.getTime())/3600000);
                            
                                        for(let i = diffhr; i < array.length; i++) {
                            
                                            let a = i - diffhr
                            
                            

                            und es dann rausgeschmissen weil ich da die Datenpunkte mit Stunden kleiner 10 mit führender Null haben wollte wegen der Sortierung.
                            Ich mach da mal weiter und poste meinen aktuellen Stand wenn er läuft.

                            paul53P 1 Antwort Letzte Antwort
                            0
                            • O ostseeskipper

                              @paul53
                              Das Script ist war ne gute Basis und dafür das es aus 2020 ist ne gute Arbeit.

                              Mir gefiel einiges nicht daran und bin noch am probieren und testen.
                              Unter anderen, das Datenpunkt anlegen ohne if(exitsState) was du nun schon geändert hast.

                              Habe auch lange gerätselt wozu das hier ist.

                                          var jetzt = new Date(),
                              
                                              midn = new Date(
                              
                                                  jetzt.getFullYear(),
                              
                                                  jetzt.getMonth(),
                              
                                                  jetzt.getDate(),
                              
                                                  0,0,0),
                              
                                              diffhr = Math.floor((jetzt.getTime() - midn.getTime())/3600000);
                              
                                          for(let i = diffhr; i < array.length; i++) {
                              
                                              let a = i - diffhr
                              
                              

                              und es dann rausgeschmissen weil ich da die Datenpunkte mit Stunden kleiner 10 mit führender Null haben wollte wegen der Sortierung.
                              Ich mach da mal weiter und poste meinen aktuellen Stand wenn er läuft.

                              paul53P Offline
                              paul53P Offline
                              paul53
                              schrieb am zuletzt editiert von paul53
                              #41

                              @ostseeskipper sagte: rausgeschmissen weil ich da die Datenpunkte mit Stunden kleiner 10 mit führender Null haben wollte

                              Der Bestandteil a der Datenpunkt-ID ist nicht die Uhrzeit, sondern der Stunden-Abstand zur aktuellen Uhrzeit. Deshalb fängt die Schleife auch mit der aktuellen Uhrzeit an, da Daten aus der Vergangenheit nicht interessieren.
                              Beispiel mit Abfrage um 19:00 Uhr:

                              Tibber_DP.JPG

                              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                              O 1 Antwort Letzte Antwort
                              0
                              • paul53P paul53

                                @ostseeskipper sagte: rausgeschmissen weil ich da die Datenpunkte mit Stunden kleiner 10 mit führender Null haben wollte

                                Der Bestandteil a der Datenpunkt-ID ist nicht die Uhrzeit, sondern der Stunden-Abstand zur aktuellen Uhrzeit. Deshalb fängt die Schleife auch mit der aktuellen Uhrzeit an, da Daten aus der Vergangenheit nicht interessieren.
                                Beispiel mit Abfrage um 19:00 Uhr:

                                Tibber_DP.JPG

                                O Offline
                                O Offline
                                ostseeskipper
                                schrieb am zuletzt editiert von
                                #42

                                @paul53
                                weiss nicht warum ich stündlich in der Schleife oben aktuell haben möchte.
                                Da kann man auch stündlich über "current" abrufen
                                d192be90-24d2-4a65-8e91-8663b16a7b95-grafik.png

                                Aber egal das kann sich ja jeder so bauen wie er mag.

                                @paul53 Schön das du hier bist :-)
                                Wegen einem RexEx komme ich sicherlich demnächst noch mal auf dich zu.

                                O 1 Antwort Letzte Antwort
                                1
                                • O ostseeskipper

                                  @paul53
                                  weiss nicht warum ich stündlich in der Schleife oben aktuell haben möchte.
                                  Da kann man auch stündlich über "current" abrufen
                                  d192be90-24d2-4a65-8e91-8663b16a7b95-grafik.png

                                  Aber egal das kann sich ja jeder so bauen wie er mag.

                                  @paul53 Schön das du hier bist :-)
                                  Wegen einem RexEx komme ich sicherlich demnächst noch mal auf dich zu.

                                  O Offline
                                  O Offline
                                  ostseeskipper
                                  schrieb am zuletzt editiert von ostseeskipper
                                  #43

                                  @paul53 und alle Tibber'ianer die danach suchten

                                  Da ich ab Mai auch zu Tibber wechsle möchte ich mir die Preise visualisieren und natürlich im nächsten Step auch nach rechnen(folgt später).
                                  Zudem ist es mein erstes Projekt bei dem ich den Umgang mit JSON :ghost: lernen konnte.

                                  Abruf erfolgt über die Tibber API mit einem Token. Den kann man sich hier holen.
                                  Mit einem persönlichen Token bekommt man nach bestätigter Anmeldung auch seine eigenen echten Preise.
                                  (so hab ich das zumindest verstanden und sehe ich mit meinem privaten Token)

                                  Mir war wichtig das die Datenpunkte der Stundenfolge nach beginnend mit 0 in der richtigen Reihenfolge stehen, daher werden die Datenpunkte 0-9 mit einer führenden Null angelegt.

                                  Abgerufen wird 14:01 und 15:01 weil ab da neue Daten für den Folgetag zur Verfügung stehen sollen.
                                  Zu 00:01 wird noch mal aufgerufen werden weil da dann der Tagessprung ist.
                                  Hier muss ich noch schauen ob sich die Werte für Stunde 24-47 von selbst löschen wenn diese nach Mitternacht nicht mehr über die API kommen.

                                  /* 
                                  MIT License - see LICENSE.md 
                                  Copyright (c) [2020] [Matthias Boettger <mboe78@gmail.com>]
                                  Basic unter https://github.com/Maverick78de/SMA_forecast_charging/blob/master/get_tibber_data_1.0.1.js
                                  Modifiziert ostseeskipper
                                  */
                                  
                                  const token = "5K4MVS-OjfWhK_4yrjOlFe1F6kJXPVf7eQYggo8ebAE" //PublicToken
                                  // Get Tibber Data  
                                  const url = 'https://api.tibber.com/v1-beta/gql'
                                  const baseName = '0_userdata.0.StromKosten.TibberTest.';              // Legt die Datenpunkte für Stunden unter diesen Javascript-Objektordner an
                                  let myDebugLevel = 'info';  // LogLevel
                                  
                                  function requestData() {
                                   
                                      const options = {
                                          uri: url,
                                          method: 'POST',
                                          body: '{"query": "{ viewer { homes { currentSubscription{ priceInfo{ today{ total energy tax startsAt } tomorrow{ total energy tax startsAt } } } } } }" }',
                                          headers: {
                                              'Authorization': token,
                                          'Content-Type': 'application/json'
                                          }
                                      }
                                      
                                      request(options, (error, response, body) => {
                                          
                                          if(error) return console.log(error);
                                   
                                          if(response.statusCode == 200) {
                                              let array = JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.today
                                                  array = array.concat(JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.tomorrow)
                                  
                                      for(var i = 0; i < 48; i++) {        // 48 Datenpunkte
                                  
                                  
                                          
                                                  let lfd_Std = i + '.';
                                          
                                                  if(i < 10) lfd_Std = '0' + lfd_Std; // voranstehende 0
                                          
                                  
                                                  let price = Number(array[i].total)*100;
                                                  
                                                  let energy = Number(array[i].energy) *100;                
                                                  
                                                  let tax = Number(array[i].tax) *100;                
                                  
                                                  let start = String(new Date(Date.parse(array[i].startsAt)));
                                  
                                  
                                                  if(existsState(baseName + lfd_Std + "startTime")) setState(baseName + lfd_Std + "startTime", start, true);
                                                  else createState(baseName + lfd_Std + "startTime", start, {
                                  
                                                      read: true,
                                                      write: false,
                                                      name: "Gultigkeitsbeginn",
                                                      type: "string",
                                                      def: ''
                                  
                                                  });
                                  
                                                  if(existsState(baseName + lfd_Std + "Total_Preis")) setState(baseName + lfd_Std + "Total_Preis", price, true);
                                                  else createState(baseName + lfd_Std + "Total_Preis", price, {
                                  
                                                      read: true,
                                                      write: false,
                                                      name: "Total_Preis",
                                                      type: "number",
                                                      unit: "ct/kWh",
                                                      def: 0
                                  
                                                  });
                                  
                                                  if(existsState(baseName + lfd_Std + "Tax")) setState(baseName + lfd_Std + "Tax", tax, true);
                                                  else createState(baseName + lfd_Std + "Tax", tax, {
                                  
                                                      read: true,
                                                      write: false,
                                                      name: "Tax (Abgaben)",
                                                      type: "number",
                                                      unit: "ct/kWh",
                                                      def: 0
                                  
                                                  });
                                  
                                                  if(existsState(baseName + lfd_Std + "EPEX_Preis")) setState(baseName + lfd_Std + "EPEX_Preis", energy, true);
                                                  else createState(baseName + lfd_Std + "EPEX_Preis", energy, {
                                  
                                                      read: true,
                                                      write: false,
                                                      name: "EPEX_Preis",
                                                      type: "number",
                                                      unit: "ct/kWh",
                                                      def: 0
                                  
                                                  });
                                  /*      
                                   console.log('energy :'+ energy );  
                                   console.log('Variable :' + [i] );  
                                   console.log('Start :' + startTime );  
                                  */
                                              };
                                          };
                                      });
                                  }
                                  requestData(); // 1x Abruf bei Scriptstart
                                  
                                  
                                  schedule('1 0,14,15 * * *', function () { // 00:01 14:01 und 15:01 holen
                                  
                                      requestData();
                                  });
                                  

                                  EDIT: Vorschlag paul53 übernommen

                                  paul53P 1 Antwort Letzte Antwort
                                  0
                                  • O ostseeskipper

                                    @paul53 und alle Tibber'ianer die danach suchten

                                    Da ich ab Mai auch zu Tibber wechsle möchte ich mir die Preise visualisieren und natürlich im nächsten Step auch nach rechnen(folgt später).
                                    Zudem ist es mein erstes Projekt bei dem ich den Umgang mit JSON :ghost: lernen konnte.

                                    Abruf erfolgt über die Tibber API mit einem Token. Den kann man sich hier holen.
                                    Mit einem persönlichen Token bekommt man nach bestätigter Anmeldung auch seine eigenen echten Preise.
                                    (so hab ich das zumindest verstanden und sehe ich mit meinem privaten Token)

                                    Mir war wichtig das die Datenpunkte der Stundenfolge nach beginnend mit 0 in der richtigen Reihenfolge stehen, daher werden die Datenpunkte 0-9 mit einer führenden Null angelegt.

                                    Abgerufen wird 14:01 und 15:01 weil ab da neue Daten für den Folgetag zur Verfügung stehen sollen.
                                    Zu 00:01 wird noch mal aufgerufen werden weil da dann der Tagessprung ist.
                                    Hier muss ich noch schauen ob sich die Werte für Stunde 24-47 von selbst löschen wenn diese nach Mitternacht nicht mehr über die API kommen.

                                    /* 
                                    MIT License - see LICENSE.md 
                                    Copyright (c) [2020] [Matthias Boettger <mboe78@gmail.com>]
                                    Basic unter https://github.com/Maverick78de/SMA_forecast_charging/blob/master/get_tibber_data_1.0.1.js
                                    Modifiziert ostseeskipper
                                    */
                                    
                                    const token = "5K4MVS-OjfWhK_4yrjOlFe1F6kJXPVf7eQYggo8ebAE" //PublicToken
                                    // Get Tibber Data  
                                    const url = 'https://api.tibber.com/v1-beta/gql'
                                    const baseName = '0_userdata.0.StromKosten.TibberTest.';              // Legt die Datenpunkte für Stunden unter diesen Javascript-Objektordner an
                                    let myDebugLevel = 'info';  // LogLevel
                                    
                                    function requestData() {
                                     
                                        const options = {
                                            uri: url,
                                            method: 'POST',
                                            body: '{"query": "{ viewer { homes { currentSubscription{ priceInfo{ today{ total energy tax startsAt } tomorrow{ total energy tax startsAt } } } } } }" }',
                                            headers: {
                                                'Authorization': token,
                                            'Content-Type': 'application/json'
                                            }
                                        }
                                        
                                        request(options, (error, response, body) => {
                                            
                                            if(error) return console.log(error);
                                     
                                            if(response.statusCode == 200) {
                                                let array = JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.today
                                                    array = array.concat(JSON.parse(body).data.viewer.homes[0].currentSubscription.priceInfo.tomorrow)
                                    
                                        for(var i = 0; i < 48; i++) {        // 48 Datenpunkte
                                    
                                    
                                            
                                                    let lfd_Std = i + '.';
                                            
                                                    if(i < 10) lfd_Std = '0' + lfd_Std; // voranstehende 0
                                            
                                    
                                                    let price = Number(array[i].total)*100;
                                                    
                                                    let energy = Number(array[i].energy) *100;                
                                                    
                                                    let tax = Number(array[i].tax) *100;                
                                    
                                                    let start = String(new Date(Date.parse(array[i].startsAt)));
                                    
                                    
                                                    if(existsState(baseName + lfd_Std + "startTime")) setState(baseName + lfd_Std + "startTime", start, true);
                                                    else createState(baseName + lfd_Std + "startTime", start, {
                                    
                                                        read: true,
                                                        write: false,
                                                        name: "Gultigkeitsbeginn",
                                                        type: "string",
                                                        def: ''
                                    
                                                    });
                                    
                                                    if(existsState(baseName + lfd_Std + "Total_Preis")) setState(baseName + lfd_Std + "Total_Preis", price, true);
                                                    else createState(baseName + lfd_Std + "Total_Preis", price, {
                                    
                                                        read: true,
                                                        write: false,
                                                        name: "Total_Preis",
                                                        type: "number",
                                                        unit: "ct/kWh",
                                                        def: 0
                                    
                                                    });
                                    
                                                    if(existsState(baseName + lfd_Std + "Tax")) setState(baseName + lfd_Std + "Tax", tax, true);
                                                    else createState(baseName + lfd_Std + "Tax", tax, {
                                    
                                                        read: true,
                                                        write: false,
                                                        name: "Tax (Abgaben)",
                                                        type: "number",
                                                        unit: "ct/kWh",
                                                        def: 0
                                    
                                                    });
                                    
                                                    if(existsState(baseName + lfd_Std + "EPEX_Preis")) setState(baseName + lfd_Std + "EPEX_Preis", energy, true);
                                                    else createState(baseName + lfd_Std + "EPEX_Preis", energy, {
                                    
                                                        read: true,
                                                        write: false,
                                                        name: "EPEX_Preis",
                                                        type: "number",
                                                        unit: "ct/kWh",
                                                        def: 0
                                    
                                                    });
                                    /*      
                                     console.log('energy :'+ energy );  
                                     console.log('Variable :' + [i] );  
                                     console.log('Start :' + startTime );  
                                    */
                                                };
                                            };
                                        });
                                    }
                                    requestData(); // 1x Abruf bei Scriptstart
                                    
                                    
                                    schedule('1 0,14,15 * * *', function () { // 00:01 14:01 und 15:01 holen
                                    
                                        requestData();
                                    });
                                    

                                    EDIT: Vorschlag paul53 übernommen

                                    paul53P Offline
                                    paul53P Offline
                                    paul53
                                    schrieb am zuletzt editiert von
                                    #44

                                    @ostseeskipper
                                    Zeilen 36, 37 würde ich so programmieren:

                                            let lfd_Std = i + '.';
                                            if(i < 10) lfd_Std = '0' + lfd_Std; // voranstehende 0
                                    

                                    Wenn man multipliziert, muss man nicht per Number() wandeln. Es erfolgt eine implizite Typwandlung.
                                    Richtige Schreibweise der Maßeinheit: "ct/kWh"

                                    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                    O 1 Antwort Letzte Antwort
                                    2
                                    • paul53P paul53

                                      @ostseeskipper
                                      Zeilen 36, 37 würde ich so programmieren:

                                              let lfd_Std = i + '.';
                                              if(i < 10) lfd_Std = '0' + lfd_Std; // voranstehende 0
                                      

                                      Wenn man multipliziert, muss man nicht per Number() wandeln. Es erfolgt eine implizite Typwandlung.
                                      Richtige Schreibweise der Maßeinheit: "ct/kWh"

                                      O Offline
                                      O Offline
                                      ostseeskipper
                                      schrieb am zuletzt editiert von
                                      #45

                                      @paul53 said in JavaScript zum Auslesen der Tibber API?:

                                      Ok, ist übernommen. Danke für den Tip und den Hinweis:+1:

                                      O 1 Antwort Letzte Antwort
                                      1
                                      • O ostseeskipper

                                        @paul53 said in JavaScript zum Auslesen der Tibber API?:

                                        Ok, ist übernommen. Danke für den Tip und den Hinweis:+1:

                                        O Offline
                                        O Offline
                                        ostseeskipper
                                        schrieb am zuletzt editiert von
                                        #46

                                        @paul53 zum angekündigten RegEx

                                        Nachdem der Abruf der Strompreise erledigt ist möchte ich die laufenden Stromkosten pro Stunde errechnen.
                                        Dazu brauche ich den jeweils gültigen Strompreis der Stunde.
                                        Hierzu wollte ich mit der jeweils aktuellen Uhrzeit

                                            let search_Std = new Date().substr(0,18);
                                        

                                        = Thu Apr 13 2023 00

                                        im Verzeichnis nach der startTime (gelb) suchen und den rot markierte Wert zurück geben.
                                        c92e8023-2b37-4500-9ea7-9b12e8b56702-grafik.png

                                        Im Excel wäre das so was wie sverweis()

                                        Warum so kompliziert? tja gegen Mitternacht wenn der Tag springt, reicht der einfache verweis auf Datenpunkt 00 leider nicht aus, da es eventuell auch noch in Datenpunkt 24 stehen könnte.

                                        Habe auch überlegt um Mitternacht direkt den Preis von Tipper über die API aus dem Bereich Current
                                        ee4d3701-9761-4068-aeb5-9cde3115b856-grafik.png
                                        zu holen, aber hier ist die Frage wie syncron sind Uhren und manchmal soll die API temporär auch nicht erreichbar sein.
                                        Um einen Uhrenvergleich kommt man nicht drumrum.

                                        paul53P 1 Antwort Letzte Antwort
                                        0
                                        • O ostseeskipper

                                          @paul53 zum angekündigten RegEx

                                          Nachdem der Abruf der Strompreise erledigt ist möchte ich die laufenden Stromkosten pro Stunde errechnen.
                                          Dazu brauche ich den jeweils gültigen Strompreis der Stunde.
                                          Hierzu wollte ich mit der jeweils aktuellen Uhrzeit

                                              let search_Std = new Date().substr(0,18);
                                          

                                          = Thu Apr 13 2023 00

                                          im Verzeichnis nach der startTime (gelb) suchen und den rot markierte Wert zurück geben.
                                          c92e8023-2b37-4500-9ea7-9b12e8b56702-grafik.png

                                          Im Excel wäre das so was wie sverweis()

                                          Warum so kompliziert? tja gegen Mitternacht wenn der Tag springt, reicht der einfache verweis auf Datenpunkt 00 leider nicht aus, da es eventuell auch noch in Datenpunkt 24 stehen könnte.

                                          Habe auch überlegt um Mitternacht direkt den Preis von Tipper über die API aus dem Bereich Current
                                          ee4d3701-9761-4068-aeb5-9cde3115b856-grafik.png
                                          zu holen, aber hier ist die Frage wie syncron sind Uhren und manchmal soll die API temporär auch nicht erreichbar sein.
                                          Um einen Uhrenvergleich kommt man nicht drumrum.

                                          paul53P Offline
                                          paul53P Offline
                                          paul53
                                          schrieb am zuletzt editiert von
                                          #47

                                          @ostseeskipper sagte: im Verzeichnis nach der startTime (gelb) suchen und den rot markierte Wert zurück geben.

                                          Dafür kann man den $-Selektor verwenden.

                                          const idsStart = $('*.Tibber.*.startTime');
                                          var price = 0;
                                          
                                          // innerhalb der Callback-Funktion: 
                                          let search_Std = new Date().toString().substring(0, 18);
                                          idsStart.each(function(id) {
                                              if(getState(id).val.substring(0, 18) == search_Std) {
                                                  price = getState(id.replace('startTime', 'Total_Price')).val;
                                                  return;
                                              }
                                          });
                                          // mit price weiter rechnen
                                          

                                          Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                                          Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                                          O 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

                                          786

                                          Online

                                          32.4k

                                          Benutzer

                                          81.5k

                                          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