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. ioBroker Allgemein
  4. JSON Table erstellen

NEWS

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

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

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

JSON Table erstellen

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
json string
45 Beiträge 8 Kommentatoren 12.8k Aufrufe 12 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.
  • bergjetB bergjet

    @paul53
    Ich möchte allgemein wissen wie man kürzt.
    Also z.B. sollen bei table[i].Name = getState(ids[i].replace('Preis', 'Name')).val; nur die ersten 10 Zeichen angezeigt werden.

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

    @bergjet sagte: nur die ersten 10 Zeichen

    table[i].Name = getState(ids[i].replace('Preis', 'Name')).val.substr(0, 10);
    

    Siehe Methoden.

    Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
    Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

    1 Antwort Letzte Antwort
    1
    • MIC1981M Offline
      MIC1981M Offline
      MIC1981
      schrieb am zuletzt editiert von
      #42

      Vielleicht kann mir jemand helfen. Habe folgendes Skript erstellt/kopiert.

      var dps = [
      '0_userdata.0.Strom.BATEntladung'
      ];
      on({id: dps, change: 'ne'}, function (dp) {
          var data = [];
          dps.forEach( function(item) {
              var value = getState(item);
              data.push({'pv' : {'power' : value.val}})
          });
          setState('0_userdata.0.Strom.SenecVictron', JSON.stringify(data), true);
      });
      

      Dies funktioniert soweit auch. Nur die Formatierung passt noch nicht zur Weiterverwendung.
      Der Datenpunkt schaut jetzt so aus:

      [
        {
          "pv": {
            "power": 372.53
          }
        }
      ]
      

      Wie bekomme ich die eckigen Klammern weg? Danke schonmal.

      mickymM 1 Antwort Letzte Antwort
      0
      • MIC1981M MIC1981

        Vielleicht kann mir jemand helfen. Habe folgendes Skript erstellt/kopiert.

        var dps = [
        '0_userdata.0.Strom.BATEntladung'
        ];
        on({id: dps, change: 'ne'}, function (dp) {
            var data = [];
            dps.forEach( function(item) {
                var value = getState(item);
                data.push({'pv' : {'power' : value.val}})
            });
            setState('0_userdata.0.Strom.SenecVictron', JSON.stringify(data), true);
        });
        

        Dies funktioniert soweit auch. Nur die Formatierung passt noch nicht zur Weiterverwendung.
        Der Datenpunkt schaut jetzt so aus:

        [
          {
            "pv": {
              "power": 372.53
            }
          }
        ]
        

        Wie bekomme ich die eckigen Klammern weg? Danke schonmal.

        mickymM Offline
        mickymM Offline
        mickym
        Most Active
        schrieb am zuletzt editiert von mickym
        #43

        gelöscht

        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

        MIC1981M 1 Antwort Letzte Antwort
        0
        • mickymM mickym

          gelöscht

          MIC1981M Offline
          MIC1981M Offline
          MIC1981
          schrieb am zuletzt editiert von
          #44

          @mickym Danke für deine schnelle Unterstützung. Ich glaube auch, dass ich gerade mit Kanonen auf Spatzen schieße. Eigentlich möchte ich nur einen einzelnen Datenpunkt als JSON in einen anderen kopieren um diesen per MQTT zu publishen. Dieses kurze Skript hat mich meinem Ziel am weitesten gebracht, was die Formatierung angeht. Es sollen noch weitere Datenpunkte zum JSON hinzukommen, aber erstmal ist dies für mich ausreichend.

          1 Antwort Letzte Antwort
          0
          • C Offline
            C Offline
            Coffeelover
            schrieb am zuletzt editiert von
            #45

            Hallo,
            ich habe das Script hier aufgegriffen, weil ich damit PV Ertragswerte schreiben möchte. Mein Problem/Ziel: Ich möchte täglich den Max.Wert fortschreiben, also später eine Historie der Werte haben. Mein Wechselrichter gibt diesen Wert auch aus und nullt ihn täglich um Mitternacht. Wie muss ich das Script anpassen, um die Werte fortzuschreiben?

            Danke.

            '{"time":{"start":"00:00","end":"23:59","mode":"minutes","interval":1},"period":{"days":1}}'
            
            const idTable = '0_userdata.0.PV.PV_Tagesertrag_AC'; // ID JSON-Tabelle
            const ids = ['opendtu.0.116000006952.ac.phase_1.yieldday']; 
             
            var table = [];
            const tomorrow = Date.now();
            for(let i = 0; i < ids.length; i++) {
                table[i] = {};
                table[i].Name = getObject(ids[i]).common.name;
                table[i].Date = formatDate(new Date(), 'TT/MM/YYYY')
                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);
            });
            
            1 Antwort Letzte Antwort
            0

            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
            FAQ Cloud / IOT
            HowTo: Node.js-Update
            HowTo: Backup/Restore
            Downloads
            BLOG

            530

            Online

            32.7k

            Benutzer

            82.6k

            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