Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. JavaScript
    5. [gelöst] Wie json automatisch Datenpunkte in richtige Verz.?

    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] Wie json automatisch Datenpunkte in richtige Verz.?

    This topic has been deleted. Only users with topic management privileges can see it.
    • haus-automatisierung
      haus-automatisierung Developer Most Active @maxclaudi last edited by haus-automatisierung

      @maxclaudi Sowas?

      const data = '{"messageId":9875,"product":"solarFlow","deviceId":"aAbCdEx9","timestamp":1748131755,"properties":{"remainOutTime":1752,"batteryElectric":-34},"packData":[{"power":65,"sn":"CO4ABCDE090104"},{"power": 54,"sn":"CO4ABCDE090110"},{"power":54,"sn":"CO4ABCDE090108"}]}';
      const dataObj = JSON.parse(data);
      
      const prefix = '0_userdata.0.blabla';
      
      for (const pack of dataObj.packData) {
          const sn = pack.sn;
          const path = `${prefix}.${sn}`;
      
          if (!existsObject(path)) {
              setObject(path, {
                  type: 'folder',
                  common: {
                      name: sn,
                  },
                  native: {},
              });
          }
      
          for (const [key, value] of Object.entries(pack)) {
              if (key !== 'sn') {
                  const statePath = `${path}.${key}`;
                  if (existsState(statePath)) {
                      setState(statePath, value, true);
                  } else {
                      createState(statePath, value);
                  }
              }
          }
      }
      
      maxclaudi 1 Reply Last reply Reply Quote 0
      • maxclaudi
        maxclaudi @haus-automatisierung last edited by

        @haus-automatisierung

        wow 🙂

        Kann's leider nicht sofort testen, aber sieht gut aus 👍

        Dankeschön schon mal.

        haus-automatisierung 1 Reply Last reply Reply Quote 0
        • haus-automatisierung
          haus-automatisierung Developer Most Active @maxclaudi last edited by

          Du könntest sonst auch noch den Timestamp aus dem Payload mit übernehmen:

          const data = '{"messageId":9875,"product":"solarFlow","deviceId":"aAbCdEx9","timestamp":1748131755,"properties":{"remainOutTime":1752,"batteryElectric":-34},"packData":[{"power":66,"sn":"CO4ABCDE090104"},{"power": 54,"sn":"CO4ABCDE090110"},{"power":54,"sn":"CO4ABCDE090108"}]}';
          const dataObj = JSON.parse(data);
          
          const prefix = '0_userdata.0.blabla';
          
          const ts = dataObj.timestamp * 1000;
          
          for (const pack of dataObj.packData) {
              const sn = pack.sn;
              const path = `${prefix}.${sn}`;
          
              if (!existsObject(path)) {
                  setObject(path, {
                      type: 'folder',
                      common: {
                          name: sn,
                      },
                      native: {},
                  });
              }
          
              for (const [key, val] of Object.entries(pack)) {
                  if (key !== 'sn') {
                      const statePath = `${path}.${key}`;
                      if (existsState(statePath)) {
                          setState(statePath, { val, ts, ack: true });
                      } else {
                          createState(statePath, val);
                      }
                  }
              }
          }
          
          maxclaudi 2 Replies Last reply Reply Quote 1
          • maxclaudi
            maxclaudi @haus-automatisierung last edited by maxclaudi

            @haus-automatisierung
            supi 👍
            Schade, dass ich nicht gleich loslegen kann.
            Großes Dankeschön schon mal 🙂

            1 Reply Last reply Reply Quote 0
            • maxclaudi
              maxclaudi @haus-automatisierung last edited by

              @haus-automatisierung

              Hab das mal versucht.

              Wenn ich den mqtt Datenpunkt in einem Blockly trigger und dann die Funktion ausführe:

              Funktionsname: separate
              Variable: "id": folder (z. B.: 0_userdata.0.Datenpunkte.solarflow.HUB)
              Variable: wert: Json nach Objekt, getriggerter JSON-Wert

              funktion-Blockly-01.png

              Funktion:

              const data = wert; 
              const dataObj = JSON.parse(data);
               
              const prefix = id;
               
              for (const pack of dataObj.packData) {
                  const sn = pack.sn;
                  const path = `${prefix}.${sn}`;
               
                  if (!existsObject(path)) {
                      setObject(path, {
                          type: 'folder',
                          common: {
                              name: sn,
                          },
                          native: {},
                      });
                  }
               
                  for (const [key, value] of Object.entries(pack)) {
                      if (key !== 'sn') {
                          const statePath = `${path}.${key}`;
                          if (existsState(statePath)) {
                              setState(statePath, value, true);
                          } else {
                              createState(statePath, value);
                          }
                      }
                  }
              }
              
              

              error:
              SyntaxError: "[object Object]" is not valid JSON


              ok, dann Blockly geändert zu:
              wert: getriggerter JSON-Wert

              error
              TypeError: dataObj.packData is not iterable

              hmmm?

              haus-automatisierung 2 Replies Last reply Reply Quote 0
              • haus-automatisierung
                haus-automatisierung Developer Most Active @maxclaudi last edited by

                @maxclaudi Dann ist der Wert schon ein Objekt und kein String (JSON) mehr. Also kann JSON.parse weg.

                Aber warum überhaupt Blockly? Die 3 Zeilen für den Trigger kannst jetzt auch noch direkt in JS schreiben… 🙂

                1 Reply Last reply Reply Quote 0
                • haus-automatisierung
                  haus-automatisierung Developer Most Active @maxclaudi last edited by haus-automatisierung

                  const prefix = '0_userdata.0.Datenpunkte.solarflow.HUB';
                  
                  on({ id: '...', change: 'ne' }, async (obj) => {
                      const dataObj = typeof obj.state.val === 'string' ? JSON.parse(obj.state.val) : obj.state.val;
                  
                      const ts = dataObj.timestamp * 1000;
                  
                      for (const pack of dataObj.packData) {
                          const sn = pack.sn;
                          const path = `${prefix}.${sn}`;
                  
                          if (!existsObject(path)) {
                              setObject(path, {
                                  type: 'folder',
                                  common: {
                                      name: sn,
                                  },
                                  native: {},
                              });
                          }
                  
                          for (const [key, val] of Object.entries(pack)) {
                              if (key !== 'sn') {
                                  const statePath = `${path}.${key}`;
                                  if (existsState(statePath)) {
                                      setState(statePath, { val, ts, ack: true });
                                  } else {
                                      createState(statePath, val);
                                  }
                              }
                          }
                      }
                  });
                  
                  maxclaudi 1 Reply Last reply Reply Quote 0
                  • maxclaudi
                    maxclaudi @haus-automatisierung last edited by maxclaudi

                    @haus-automatisierung

                    Ohne Blockly mit Deinem letzten Code gleiches Problem:

                    funktion-Blockly-03.png

                    const prefix = '0_userdata.0.Datenpunkte.solarflow.HUB2000';
                     
                    on({ id: 'mqtt.1.A8yh63.xxxxx.properties.report', change: 'ne' }, async (obj) => {
                        const dataObj = typeof obj.state.val === 'string' ? JSON.parse(obj.state.val) : obj.state.val;
                     
                        const ts = dataObj.timestamp * 1000;
                     
                        for (const pack of dataObj.packData) {
                            const sn = pack.sn;
                            const path = `${prefix}.${sn}`;
                     
                            if (!existsObject(path)) {
                                setObject(path, {
                                    type: 'folder',
                                    common: {
                                        name: sn,
                                    },
                                    native: {},
                                });
                            }
                     
                            for (const [key, val] of Object.entries(pack)) {
                                if (key !== 'sn') {
                                    const statePath = `${path}.${key}`;
                                    if (existsState(statePath)) {
                                        setState(statePath, { val, ts, ack: true });
                                    } else {
                                        createState(statePath, val);
                                    }
                                }
                            }
                        }
                    });
                    

                    error
                    TypeError: dataObj.packData is not iterable

                    xxxxxx: wurde nur id unkenntlich gemacht


                    Edit/PS:
                    Sollte man es mit einem vorgesetzten try versuchen?
                    "packData" ist nicht immer enthalten.
                    Das allein wird aber nicht der Fehler sein?


                    edit:
                    wie geschrieben, hier funktioniert die iteration.

                    for(let i in obj) {
                        if(typeof obj[i] == 'object') iter(id + '.' + i, obj[i]);
                        else {
                            if(existsState(id + '.' + i)) setState(id + '.' + i, obj[i], true);
                            else createState(id + '.' + i, obj[i]);
                        }
                    }
                    
                    

                    da bekommt obj den getriggerten Datenpunkt konvertiert mit "Json nach Objekt"

                    haus-automatisierung 1 Reply Last reply Reply Quote 0
                    • haus-automatisierung
                      haus-automatisierung Developer Most Active @maxclaudi last edited by haus-automatisierung

                      @maxclaudi sagte in Wie json automatisch Datenpunkte in richtige Verzeichnise?:

                      Ohne Blockly mit Deinem letzten Code gleiches Problem:

                      Ne, ist ein anderes Problem (und eine ganz andere Meldung) 🙂 Einen Schritt weiter.

                      @maxclaudi sagte in Wie json automatisch Datenpunkte in richtige Verzeichnise?:

                      "packData" ist nicht immer enthalten.

                      Ah okay, die Beispiele oben haben immer ein Array enthalten.

                      const prefix = '0_userdata.0.Datenpunkte.solarflow.HUB';
                      
                      on({ id: '...', change: 'ne' }, async (obj) => {
                          try {
                              const newVal = obj.state.val;
                              const dataObj = typeof newVal === 'string' ? JSON.parse(newVal) : newVal;
                      
                              if (dataObj.packData && Array.isArray(dataObj.packData)) {
                                  const ts = dataObj.timestamp * 1000;
                      
                                  for (const pack of dataObj.packData) {
                                      const sn = pack.sn;
                                      const path = `${prefix}.${sn}`;
                      
                                      if (!existsObject(path)) {
                                          setObject(path, {
                                              type: 'folder',
                                              common: {
                                                  name: sn,
                                              },
                                              native: {},
                                          });
                                      }
                      
                                      for (const [key, val] of Object.entries(pack)) {
                                          if (key !== 'sn') {
                                              const statePath = `${path}.${key}`;
                                              if (existsState(statePath)) {
                                                  setState(statePath, { val, ts, ack: true });
                                              } else {
                                                  createState(statePath, val);
                                              }
                                          }
                                      }
                                  }
                              }
                          } catch (err) {
                              console.error(err);
                          }
                      });
                      
                      maxclaudi 1 Reply Last reply Reply Quote 1
                      • maxclaudi
                        maxclaudi @haus-automatisierung last edited by maxclaudi

                        @haus-automatisierung

                        🙂 Dankeschön 👍

                        Script ist mal gestartet und keine Fehler.
                        es läuft 🙂

                        nur der Datenpunkt sn mit der Nummer fehlt.
                        So wie das Verzeichnis nun benannt wird, sollte der Datenpunkt selbst (sn) mit der Nummer auch vorhanden sein.

                        Schlimm ist das nicht, wenn der Rest funktioniert.

                        Mal Daten sammeln und abwarten.
                        Hast mir sehr geholfen und einiges an Zeit erspart.

                        Vielen, vielen Dank dafür 🙂

                        haus-automatisierung 1 Reply Last reply Reply Quote 0
                        • haus-automatisierung
                          haus-automatisierung Developer Most Active @maxclaudi last edited by

                          @maxclaudi sagte in Wie json automatisch Datenpunkte in richtige Verzeichnise?:

                          Einzige was ist, dass mir der Datenpunkt sn mit der Nummer fehlt.

                          Hatte ich ja explizit übersprungen, weil redundant (in der ID ja bereits enthalten). Aber hier:

                          const prefix = '0_userdata.0.Datenpunkte.solarflow.HUB';
                          
                          on({ id: '...', change: 'ne' }, async (obj) => {
                              try {
                                  const newVal = obj.state.val;
                                  const dataObj = typeof newVal === 'string' ? JSON.parse(newVal) : newVal;
                          
                                  if (dataObj.packData && Array.isArray(dataObj.packData)) {
                                      const ts = dataObj.timestamp * 1000;
                          
                                      for (const pack of dataObj.packData) {
                                          const sn = pack.sn;
                                          const path = `${prefix}.${sn}`;
                          
                                          if (!existsObject(path)) {
                                              setObject(path, {
                                                  type: 'folder',
                                                  common: {
                                                      name: sn,
                                                  },
                                                  native: {},
                                              });
                                          }
                          
                                          for (const [key, val] of Object.entries(pack)) {
                                              const statePath = `${path}.${key}`;
                                              if (existsState(statePath)) {
                                                  setState(statePath, { val, ts, ack: true });
                                              } else {
                                                  createState(statePath, val);
                                              }
                                          }
                                      }
                                  }
                              } catch (err) {
                                  console.error(err);
                              }
                          });
                          
                          maxclaudi 1 Reply Last reply Reply Quote 1
                          • maxclaudi
                            maxclaudi @haus-automatisierung last edited by maxclaudi

                            @haus-automatisierung
                            musste einige gets publishen.

                            Jetzt wird auch die sn übertragen.

                            Leider werden jetzt alle anderen states nicht mehr aktualisiert.
                            Nur packData.

                            ist ja auch klar,

                            if (dataObj.packData && Array.isArray(dataObj.packData)
                            

                            muss dann noch erweitert werden, dass alles andere OHNE packData wie bisher angelegt und aktualisiert wird.

                            haus-automatisierung 1 Reply Last reply Reply Quote 0
                            • haus-automatisierung
                              haus-automatisierung Developer Most Active @maxclaudi last edited by haus-automatisierung

                              @maxclaudi Mach doch mal ein Beispiel wie die Struktur aussehen sollte. Geht es nur um die „properties“? Die scheinen ja unabhängig von der Seriennummer zu sein und müssten dann separat gepflegt werden

                              maxclaudi 1 Reply Last reply Reply Quote 0
                              • maxclaudi
                                maxclaudi @haus-automatisierung last edited by maxclaudi

                                @haus-automatisierung

                                Die Struktur ist enorm.

                                Sie ändert sich auch immer mal wieder, weil Neues dazu kommt und Einiges selten oder gar nicht mehr aktualisiert wird.

                                Muss nur noch Deinen großartigen Code mit meinem kombinieren und noch etwas anpassen.

                                Ein ganz großes und herzliches Dankeschön 🙂

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

                                Support us

                                ioBroker
                                Community Adapters
                                Donate

                                788
                                Online

                                31.9k
                                Users

                                80.1k
                                Topics

                                1.3m
                                Posts

                                javascript
                                2
                                15
                                280
                                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