Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. [gelöst] Datenpunt aus JSON String erstellen und verarbeiten

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] Datenpunt aus JSON String erstellen und verarbeiten

    This topic has been deleted. Only users with topic management privileges can see it.
    • I
      iobroker_Alex @paul53 last edited by

      @paul53 Besten Dank funktioniert!!!

      Sag mal wie du siehst habe ich mehrere Inverter die auf gleiche Weise ausgelesen werden sollen => 5 Stück um genau zu sein.
      Um es mir am einfachsten zu machen würde ich nun das Skript 5 mal kopieren und unter anderem Namen speichern und nur oben den Path und das Objekt abändern. => Anfängermäßig

      Wie würdest du das lösen?
      Schleife drum und vorher nen Array mit den 5 Invertern und den 5 Paths anlegen?

      paul53 1 Reply Last reply Reply Quote 0
      • paul53
        paul53 @iobroker_Alex last edited by

        @iobroker_Alex sagte:

        das Skript 5 mal kopieren und unter anderem Namen speichern und nur oben den Path und das Objekt abändern. => Anfängermäßig
        Wie würdest du das lösen?

        Genauso.

        I 1 Reply Last reply Reply Quote 0
        • I
          iobroker_Alex @paul53 last edited by

          @paul53 Vielen Dank hab echt was gelernt heute 🙂

          1 Reply Last reply Reply Quote 0
          • P
            pmunz last edited by

            Vielen Dank @paul53
            Da haben wir echt etwas gelernt 🙂
            zum JSON string auslesen und in Datenpunkte speichern hätte ich da noch zwei Fragen:

            1.) wie kann man diesen JSON string auslesen wobei die werte mit einem Semicolon getrennt sind?
            {"idx":788,"RSSI":7,"nvalue":0,"svalue":"22.9;15.4;2"}

            2.) was kann man machen wenn sich in einer Objektzeile die Werte immer ändern ?
            wie bekommt man die werte getrennt voneinander in einen Datenpunkt.
            Bildschirmfoto 2020-05-07 um 14.38.23.png Bildschirmfoto 2020-05-07 um 14.37.42.png Bildschirmfoto 2020-05-07 um 14.38.07.png

            Das ESPeasy Projekt versendet den JSON string auf diese weise. Alle Werte ok aber eben immer in die selbe Objekt zeile, die Werte und der "idx" sind narürlich unterschiedlich.

            LG

            paul53 1 Reply Last reply Reply Quote 0
            • paul53
              paul53 @pmunz last edited by

              @pmunz

              on(idJson, function(dp) {
                  let obj = JSON.parse(dp.state.val);
                  if(obj.idx == 788) {
                      let arr = obj.svalue.split(';');
                      setState(idWert1 , parseFloat(arr[0]), true);
                      setState(idWert2 , parseFloat(arr[1]), true);
                      setState(idWert3 , parseFloat(arr[2]), true);
                  }
              });
              
              P 1 Reply Last reply Reply Quote 1
              • G
                guergen last edited by

                Kann ich auch jeden Tag einen automatisch einen neuen DP erstellen mit dem Datum des jeweilligen Tages?
                Ich würde gerne die maximale Leistung meiner PV-Anlage speichern....
                Hab es mit Blockly versucht, geht aber scheinbar nicht. Mit JS stehe ich "noch" auf dem Kriegspfad!

                paul53 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @guergen last edited by

                  @guergen sagte:

                  Kann ich auch jeden Tag einen automatisch einen neuen DP erstellen mit dem Datum des jeweilligen Tages?

                  Ja, unter "javascript.0" ist es möglich.

                  G 1 Reply Last reply Reply Quote 0
                  • G
                    guergen @paul53 last edited by guergen

                    @paul53 Wie übergebe ich denn als Datenpunkt den Tag?
                    Anstatt des Test1 soll das Datum stehen...

                    schedule("0 23 * * *", function () {
                      createState("PV.Test1", getState("0_userdata.0.PV.Max").val, JSON.parse('{"type":"number","unit":"W"}'), function () {
                      });
                    });
                    
                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @guergen last edited by paul53

                      @guergen sagte:

                      Anstatt des Test1 soll das Datum stehen

                      schedule("0 23 * * *", function () {
                        let datum = formatDate(new Date(), 'YYYY.O.D');
                        createState("PV." + datum, getState("0_userdata.0.PV.Max").val, {type: "number", unit: "W"});
                      });
                      

                      Die Punkte im Datum erzeugen jedes Jahr und jeden Monat einen Ordner im Tab "Objekte". Wenn das nicht gewünscht ist, ersetze die Punkte durch Bindestriche. Doku. Datum heute bei der angegebenen Formatierung:

                      2020.Mai.7
                      
                      G 1 Reply Last reply Reply Quote 0
                      • G
                        guergen @paul53 last edited by

                        @paul53 OK, verstanden...!
                        DP wird auch schon angelegt. jetzt muss ich nur noch den alten DP löschen, aber das bekomme ich hin!
                        Danke!

                        paul53 1 Reply Last reply Reply Quote 0
                        • paul53
                          paul53 @guergen last edited by

                          @guergen sagte:

                          DP wird auch schon angelegt.

                          Ist denn schon 23:00 Uhr ?
                          Wenn die Sortier-Reihenfolge im Tab "Objekte" stimmen soll, dann verwende das Format "YYYY.MM.DD".

                          G 2 Replies Last reply Reply Quote 0
                          • G
                            guergen @paul53 last edited by

                            @paul53 Na ich kann doch schonmal mit einer anderen Uhrzeit testen...
                            Habe es eben in YYYY.MM.DD geändert

                            1 Reply Last reply Reply Quote 0
                            • G
                              guergen @paul53 last edited by guergen

                              @paul53 Hmmmh... der soll den Max-Wert danach auf 0 setzen, habe ein Delay benutzt... geht nicht:

                              schedule("27 19 * * *", function () {
                              
                                let datum = formatDate(new Date(), 'YYYY.MM.DD');
                              
                                createState("PV-Max." + datum, getState("0_userdata.0.PV.Max").val, {type: "number", unit: "W"});
                                  setStateDelayed("0_userdata.0.PV.Max", 0, 30000);
                              });
                              

                              Ich befürchte, ich habe das mit den geschweiften Klammern noch nicht verstanden
                              Es schreibt den blöden Wert nicht in den neuen DP

                              1 Reply Last reply Reply Quote 0
                              • G
                                guergen last edited by guergen

                                OK, wenn der neue DP PV-Max heisst geht es nicht, lasse ich das-Max weg, geht es!

                                paul53 1 Reply Last reply Reply Quote 0
                                • paul53
                                  paul53 @guergen last edited by

                                  @guergen sagte:

                                  wenn der neue DP PV-Max heisst geht es nicht

                                  Kann ich nicht nachvollziehen.

                                  CreateState_PV-Max.JPG

                                  1 Reply Last reply Reply Quote 0
                                  • P
                                    pmunz @paul53 last edited by pmunz

                                    @paul53 sagte in Datenpunt aus JSON String erstellen und weiter verarbeiten:

                                    @pmunz

                                    on(idJson, function(dp) {
                                        let obj = JSON.parse(dp.state.val);
                                        if(obj.idx == 788) {
                                            let arr = obj.svalue.split(';');
                                            setState(idWert1 , parseFloat(arr[0]), true);
                                            setState(idWert2 , parseFloat(arr[1]), true);
                                            setState(idWert3 , parseFloat(arr[2]), true);
                                        }
                                    });
                                    

                                    @paul53
                                    Wie kann ich den in diesem fall dazugehörige Datenpunkte erzeugen ?

                                    const idVorraum_BWM1 = "mqtt.0.Vorraum_BWM1.in"; // {"idx":788,"RSSI":8,"nvalue":0,"svalue":"22.9;16.5;2"}
                                    
                                    const path = 'javascript.' + instance + '.SENSORBWM1.';
                                    
                                    const idsvalue = path + 'Temp';
                                     
                                    
                                    if(!existsState(idsvalue)) { // Datenpunkte erzeugen
                                    
                                        createState(idsvalue, 'leer', {type: 'string'});
                                    
                                    };
                                    
                                     on(idVorraum_BWM1, function(dp) {
                                    
                                        let obj = JSON.parse(dp.state.val);
                                    
                                        if(obj.idx == 788) {
                                    
                                            let arr = obj.svalue.split(';');
                                    
                                            setState(idTemp , parseFloat(arr[0]), true);
                                    
                                            setState(idHum , parseFloat(arr[1]), true);
                                            
                                            }
                                    
                                    });
                                    
                                    paul53 1 Reply Last reply Reply Quote 0
                                    • paul53
                                      paul53 @pmunz last edited by paul53

                                      @pmunz sagte in Datenpunt aus JSON String erstellen und weiter verarbeiten:

                                      const idsvalue = path + 'Temp'; if(!existsState(idsvalue)) { // Datenpunkte erzeugen createState(idsvalue, 'leer', {type: 'string'}); };

                                      Es müssen die gleichen Bezeichner verwendet werden wie bei setState().

                                      const idTemp = path + 'Temperatur';
                                      const idHum = path + 'Luftfeuchte';
                                       
                                      if(!existsState(idTemp)) { // Datenpunkte erzeugen
                                          createState(idTemp, 0, {type: 'number', unit: '°C'});
                                          createState(idHum, 0, {type: 'number', unit: '%'});
                                      };
                                      
                                      P 1 Reply Last reply Reply Quote 1
                                      • P
                                        pmunz @paul53 last edited by

                                        @paul53
                                        Alles bestens es Funktioniert !
                                        Danke

                                        paul53 1 Reply Last reply Reply Quote 0
                                        • paul53
                                          paul53 @pmunz last edited by

                                          @pmunz sagte:

                                          es Funktioniert

                                          Dann markiere bitte das Thema in der Überschrift des ersten Beitrags als [gelöst].

                                          1 Reply Last reply Reply Quote 1
                                          • First post
                                            Last post

                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          729
                                          Online

                                          31.8k
                                          Users

                                          80.0k
                                          Topics

                                          1.3m
                                          Posts

                                          blockly communication javascript
                                          5
                                          33
                                          2744
                                          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