Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • 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. Edit: JSON aus Objekten erstellen

NEWS

  • Neuer ioBroker-Blog online: Monatsrückblick März/April 2026
    BluefoxB
    Bluefox
    8
    1
    1.8k

  • Verwendung von KI bitte immer deutlich kennzeichnen
    HomoranH
    Homoran
    11
    1
    740

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    1.2k

Edit: JSON aus Objekten erstellen

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
javascript
6 Beiträge 3 Kommentatoren 430 Aufrufe 2 Beobachtet
  • Ä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.
  • M Online
    M Online
    michihorn
    schrieb am zuletzt editiert von michihorn
    #1

    Hallo ich habe vor mir die Werte einzelner Monate in eine JSON zu schreiben und zwar sobald sich ein Wert ändert.
    Die Objekte sehen so aus.
    solar.png
    Der Datenpunkt des JSON heißt Solar_Monate. Wie kann ich das Realisieren?
    Mein erster Ansatz sah so aus:

    const idTable = 'Solar_Monate'; // ID JSON-Tabelle
    const ids = ['0_userdata.0.Haus.Energie.Zählerstände.Monate.1','0_userdata.0.Haus.Energie.Zählerstände.Monate.2','0_userdata.0.Haus.Energie.Zählerstände.Monate.3','0_userdata.0.Haus.Energie.Zählerstände.Monate.4','0_userdata.0.Haus.Energie.Zählerstände.Monate.5','0_userdata.0.Haus.Energie.Zählerstände.Monate.6','0_userdata.0.Haus.Energie.Zählerstände.Monate.7','0_userdata.0.Haus.Energie.Zählerstände.Monate.8','0_userdata.0.Haus.Energie.Zählerstände.Monate.9','0_userdata.0.Haus.Energie.Zählerstände.Monate.10','0_userdata.0.Haus.Energie.Zählerstände.Monate.11','0_userdata.0.Haus.Energie.Zählerstände.Monate.12']; 
     
    var table = [];
    for(let i = 0; i < ids.length; i++) {
        table[i] = {};
        table[i].Name = getObject(ids[i]).common.name;
        table[i].Wert = getState(ids[i]).val;
    }
    setState(idTable, JSON.stringify(table), true);
     
    on(ids, function(dp) {
        let idx = ids.indexOf(dp.id);
        table[idx].Wert = dp.state.val;
        setState(idTable, JSON.stringify(table), true);
    });
    

    Gruß Michael

    paul53P 2 Antworten Letzte Antwort
    0
    • M michihorn

      Hallo ich habe vor mir die Werte einzelner Monate in eine JSON zu schreiben und zwar sobald sich ein Wert ändert.
      Die Objekte sehen so aus.
      solar.png
      Der Datenpunkt des JSON heißt Solar_Monate. Wie kann ich das Realisieren?
      Mein erster Ansatz sah so aus:

      const idTable = 'Solar_Monate'; // ID JSON-Tabelle
      const ids = ['0_userdata.0.Haus.Energie.Zählerstände.Monate.1','0_userdata.0.Haus.Energie.Zählerstände.Monate.2','0_userdata.0.Haus.Energie.Zählerstände.Monate.3','0_userdata.0.Haus.Energie.Zählerstände.Monate.4','0_userdata.0.Haus.Energie.Zählerstände.Monate.5','0_userdata.0.Haus.Energie.Zählerstände.Monate.6','0_userdata.0.Haus.Energie.Zählerstände.Monate.7','0_userdata.0.Haus.Energie.Zählerstände.Monate.8','0_userdata.0.Haus.Energie.Zählerstände.Monate.9','0_userdata.0.Haus.Energie.Zählerstände.Monate.10','0_userdata.0.Haus.Energie.Zählerstände.Monate.11','0_userdata.0.Haus.Energie.Zählerstände.Monate.12']; 
       
      var table = [];
      for(let i = 0; i < ids.length; i++) {
          table[i] = {};
          table[i].Name = getObject(ids[i]).common.name;
          table[i].Wert = getState(ids[i]).val;
      }
      setState(idTable, JSON.stringify(table), true);
       
      on(ids, function(dp) {
          let idx = ids.indexOf(dp.id);
          table[idx].Wert = dp.state.val;
          setState(idTable, JSON.stringify(table), true);
      });
      

      Gruß Michael

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

      @michihorn sagte: Die Objekte sehen so aus.

      const idTable = '0_userdata.0.Haus.Energie.Zählerstände.Monate.Solar_Monate'; // ID JSON-Tabelle
      

      Bei deiner Deklaration wird das JSON in den DP "javascript.0.Solar_Monate" geschrieben, der vermutlich nicht existiert.

      Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
      Produktiv: Asus PN 42 / N100 / 8 GB / 500 GB

      1 Antwort Letzte Antwort
      0
      • M michihorn

        Hallo ich habe vor mir die Werte einzelner Monate in eine JSON zu schreiben und zwar sobald sich ein Wert ändert.
        Die Objekte sehen so aus.
        solar.png
        Der Datenpunkt des JSON heißt Solar_Monate. Wie kann ich das Realisieren?
        Mein erster Ansatz sah so aus:

        const idTable = 'Solar_Monate'; // ID JSON-Tabelle
        const ids = ['0_userdata.0.Haus.Energie.Zählerstände.Monate.1','0_userdata.0.Haus.Energie.Zählerstände.Monate.2','0_userdata.0.Haus.Energie.Zählerstände.Monate.3','0_userdata.0.Haus.Energie.Zählerstände.Monate.4','0_userdata.0.Haus.Energie.Zählerstände.Monate.5','0_userdata.0.Haus.Energie.Zählerstände.Monate.6','0_userdata.0.Haus.Energie.Zählerstände.Monate.7','0_userdata.0.Haus.Energie.Zählerstände.Monate.8','0_userdata.0.Haus.Energie.Zählerstände.Monate.9','0_userdata.0.Haus.Energie.Zählerstände.Monate.10','0_userdata.0.Haus.Energie.Zählerstände.Monate.11','0_userdata.0.Haus.Energie.Zählerstände.Monate.12']; 
         
        var table = [];
        for(let i = 0; i < ids.length; i++) {
            table[i] = {};
            table[i].Name = getObject(ids[i]).common.name;
            table[i].Wert = getState(ids[i]).val;
        }
        setState(idTable, JSON.stringify(table), true);
         
        on(ids, function(dp) {
            let idx = ids.indexOf(dp.id);
            table[idx].Wert = dp.state.val;
            setState(idTable, JSON.stringify(table), true);
        });
        

        Gruß Michael

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

        @michihorn sagte: Mein erster Ansatz sah so aus:

        Ich würde auch die Liste ids in der Schleife erzeugen, etwa so:

        const path = '0_userdata.0.Haus.Energie.Zählerstände.Monate.';
        const idTable = path + 'Solar_Monate'; // ID JSON-Tabelle
        
        const ids = []; 
        const table = [];
        for(let i = 0; i < 12; i++) {
            const id = path + (i + 1);
            ids[i] = id;
            table[i] = {
                Name: getObject(id).common.name,
                Wert: getState(id).val 
            };
        }
        setState(idTable, JSON.stringify(table), true);
         
        on(ids, function(dp) {
            let idx = ids.indexOf(dp.id);
            table[idx].Wert = dp.state.val;
            setState(idTable, JSON.stringify(table), true);
        });
        

        Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
        Produktiv: Asus PN 42 / N100 / 8 GB / 500 GB

        M 1 Antwort Letzte Antwort
        1
        • paul53P paul53

          @michihorn sagte: Mein erster Ansatz sah so aus:

          Ich würde auch die Liste ids in der Schleife erzeugen, etwa so:

          const path = '0_userdata.0.Haus.Energie.Zählerstände.Monate.';
          const idTable = path + 'Solar_Monate'; // ID JSON-Tabelle
          
          const ids = []; 
          const table = [];
          for(let i = 0; i < 12; i++) {
              const id = path + (i + 1);
              ids[i] = id;
              table[i] = {
                  Name: getObject(id).common.name,
                  Wert: getState(id).val 
              };
          }
          setState(idTable, JSON.stringify(table), true);
           
          on(ids, function(dp) {
              let idx = ids.indexOf(dp.id);
              table[idx].Wert = dp.state.val;
              setState(idTable, JSON.stringify(table), true);
          });
          
          M Online
          M Online
          michihorn
          schrieb am zuletzt editiert von
          #4

          @paul53 Jetzt wäre noch interessant, die Tabelle zu aktuallisieren sobald sich einer der Werte in den Objekten 1-12 ändert.

          paul53P 1 Antwort Letzte Antwort
          0
          • M michihorn

            @paul53 Jetzt wäre noch interessant, die Tabelle zu aktuallisieren sobald sich einer der Werte in den Objekten 1-12 ändert.

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

            @michihorn sagte: die Tabelle zu aktuallisieren sobald sich einer der Werte in den Objekten 1-12 ändert.

            Das sollte durch den Trigger erfolgen:

            on(ids, function(dp) {
                let idx = ids.indexOf(dp.id);
                table[idx].Wert = dp.state.val;
                setState(idTable, JSON.stringify(table), true);
            });
            

            Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
            Produktiv: Asus PN 42 / N100 / 8 GB / 500 GB

            1 Antwort Letzte Antwort
            0
            • L Online
              L Online
              legro
              schrieb am zuletzt editiert von legro
              #6

              @michihorn sagte in JSON aus Objekten erstellen:

              Hallo ich habe vor mir die Werte einzelner Monate in eine JSON zu schreiben und zwar sobald sich ein Wert ändert.

              Hier habe ich u.a. genau zu solchem Vorhaben Datenstrukturen und Algorithmen entwickelt. Vielleicht hilft es dir als Ideensammlung.

              Leitideen/Strategien ..

              • Monatstabellen erstellen und mittels Trigger befüllen
              • Diese Tabellen mittels JSON.parse ins RAM als Objekt einlesen
              • Objekt mit JavaScript bearbeiten
              • Anschließend Objekt mittels JSON.stringify wieder in den Objektbaum schreiben
              • ..

              Raspberry Pi 5 mit 8GB + 120GB SSD + Coordinator COD-m + ioBroker ..

              1 Antwort Letzte Antwort
              1

              Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

              Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

              Mit deinem Input könnte dieser Beitrag noch besser werden 💗

              Registrieren Anmelden
              Antworten
              • In einem neuen Thema antworten
              Anmelden zum Antworten
              • Älteste zuerst
              • Neuste zuerst
              • Meiste Stimmen


              Support us

              ioBroker
              Community Adapters
              Donate

              580

              Online

              32.9k

              Benutzer

              83.0k

              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