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

NEWS

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    17
    1
    2.1k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    929

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

[gelöst] Wie json automatisch Datenpunkte in richtige Verz.?

Geplant Angeheftet Gesperrt Verschoben JavaScript
javascript
15 Beiträge 2 Kommentatoren 938 Aufrufe 2 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.
  • maxclaudiM maxclaudi

    @haus-automatisierung

    wow :-)

    Kann's leider nicht sofort testen, aber sieht gut aus :+1:

    Dankeschön schon mal.

    haus-automatisierungH Online
    haus-automatisierungH Online
    haus-automatisierung
    Developer Most Active
    schrieb am zuletzt editiert von
    #4

    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);
                }
            }
        }
    }
    

    🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
    🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
    📚 Meine inoffizielle ioBroker Dokumentation

    maxclaudiM 2 Antworten Letzte Antwort
    1
    • haus-automatisierungH haus-automatisierung

      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);
                  }
              }
          }
      }
      
      maxclaudiM Offline
      maxclaudiM Offline
      maxclaudi
      schrieb am zuletzt editiert von maxclaudi
      #5

      @haus-automatisierung
      supi :+1:
      Schade, dass ich nicht gleich loslegen kann.
      Großes Dankeschön schon mal :-)

      Ich schreibe meistens sehr direkt – bitte nicht falsch verstehen, es ist nie böse gemeint. Das ist einfach mein Stil und niemals abwertend gemeint.

      1 Antwort Letzte Antwort
      0
      • haus-automatisierungH haus-automatisierung

        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);
                    }
                }
            }
        }
        
        maxclaudiM Offline
        maxclaudiM Offline
        maxclaudi
        schrieb am zuletzt editiert von
        #6

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

        Ich schreibe meistens sehr direkt – bitte nicht falsch verstehen, es ist nie böse gemeint. Das ist einfach mein Stil und niemals abwertend gemeint.

        haus-automatisierungH 2 Antworten Letzte Antwort
        0
        • maxclaudiM maxclaudi

          @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-automatisierungH Online
          haus-automatisierungH Online
          haus-automatisierung
          Developer Most Active
          schrieb am zuletzt editiert von
          #7

          @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… :)

          🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
          🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
          📚 Meine inoffizielle ioBroker Dokumentation

          1 Antwort Letzte Antwort
          0
          • maxclaudiM maxclaudi

            @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-automatisierungH Online
            haus-automatisierungH Online
            haus-automatisierung
            Developer Most Active
            schrieb am zuletzt editiert von haus-automatisierung
            #8
            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);
                            }
                        }
                    }
                }
            });
            

            🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
            🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
            📚 Meine inoffizielle ioBroker Dokumentation

            maxclaudiM 1 Antwort Letzte Antwort
            0
            • haus-automatisierungH 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);
                              }
                          }
                      }
                  }
              });
              
              maxclaudiM Offline
              maxclaudiM Offline
              maxclaudi
              schrieb am zuletzt editiert von maxclaudi
              #9

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

              Ich schreibe meistens sehr direkt – bitte nicht falsch verstehen, es ist nie böse gemeint. Das ist einfach mein Stil und niemals abwertend gemeint.

              haus-automatisierungH 1 Antwort Letzte Antwort
              0
              • maxclaudiM 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-automatisierungH Online
                haus-automatisierungH Online
                haus-automatisierung
                Developer Most Active
                schrieb am zuletzt editiert von haus-automatisierung
                #10

                @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);
                    }
                });
                

                🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                📚 Meine inoffizielle ioBroker Dokumentation

                maxclaudiM 1 Antwort Letzte Antwort
                1
                • haus-automatisierungH 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);
                      }
                  });
                  
                  maxclaudiM Offline
                  maxclaudiM Offline
                  maxclaudi
                  schrieb am zuletzt editiert von maxclaudi
                  #11

                  @haus-automatisierung

                  :-) Dankeschön :+1:

                  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 :-)

                  Ich schreibe meistens sehr direkt – bitte nicht falsch verstehen, es ist nie böse gemeint. Das ist einfach mein Stil und niemals abwertend gemeint.

                  haus-automatisierungH 1 Antwort Letzte Antwort
                  0
                  • maxclaudiM maxclaudi

                    @haus-automatisierung

                    :-) Dankeschön :+1:

                    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-automatisierungH Online
                    haus-automatisierungH Online
                    haus-automatisierung
                    Developer Most Active
                    schrieb am zuletzt editiert von
                    #12

                    @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);
                        }
                    });
                    

                    🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                    🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                    📚 Meine inoffizielle ioBroker Dokumentation

                    maxclaudiM 1 Antwort Letzte Antwort
                    1
                    • haus-automatisierungH haus-automatisierung

                      @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);
                          }
                      });
                      
                      maxclaudiM Offline
                      maxclaudiM Offline
                      maxclaudi
                      schrieb am zuletzt editiert von maxclaudi
                      #13

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

                      Ich schreibe meistens sehr direkt – bitte nicht falsch verstehen, es ist nie böse gemeint. Das ist einfach mein Stil und niemals abwertend gemeint.

                      haus-automatisierungH 1 Antwort Letzte Antwort
                      0
                      • maxclaudiM 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-automatisierungH Online
                        haus-automatisierungH Online
                        haus-automatisierung
                        Developer Most Active
                        schrieb am zuletzt editiert von haus-automatisierung
                        #14

                        @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

                        🧑‍🎓 Autor des beliebten ioBroker-Master-Kurses
                        🎥 Tutorials rund um das Thema DIY-Smart-Home: https://haus-automatisierung.com/
                        📚 Meine inoffizielle ioBroker Dokumentation

                        maxclaudiM 1 Antwort Letzte Antwort
                        0
                        • haus-automatisierungH 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

                          maxclaudiM Offline
                          maxclaudiM Offline
                          maxclaudi
                          schrieb am zuletzt editiert von maxclaudi
                          #15

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

                          Ich schreibe meistens sehr direkt – bitte nicht falsch verstehen, es ist nie böse gemeint. Das ist einfach mein Stil und niemals abwertend gemeint.

                          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

                          706

                          Online

                          32.6k

                          Benutzer

                          82.2k

                          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