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
    935

  • 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 939 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.
  • 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

                      658

                      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