Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. JSON Table erstellen

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    JSON Table erstellen

    This topic has been deleted. Only users with topic management privileges can see it.
    • bergjet
      bergjet @OliverIO last edited by

      @oliverio Ich habe da wenig Ahnung, bin nur Anwender.
      Das Widget heißt (Materialdesign-Bar Chart)

      1 Reply Last reply Reply Quote 0
      • OliverIO
        OliverIO @OliverIO last edited by

        @bergjet

        @oliverio sagte in JSON Table erstellen:

        das es label und nicht title heißen muss

        bergjet 1 Reply Last reply Reply Quote 0
        • bergjet
          bergjet @OliverIO last edited by

          @oliverio
          Habe es auf Label geändert:

          var dps =[
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.00-01",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.01-02",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.02-03",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.03-04",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.04-05",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.05-06",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.07-08",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.08-09",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.09-10",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.10-11",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.11-12",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.12-13",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.13-14",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.14-15",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.15-16",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.16-17",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.17-18",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.18-19",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.19-20",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.20-21",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.21-22",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.22-23",
          "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.23-00"
          ];
           
          on({id: dps, change: 'ne'}, function (dp) {
              var data = [];
              dps.forEach( function(item) {
                  var value = getState(item);
                  data.push({'label' : item,'value' : value.val})
              });
              setState('0_userdata.0.EnergyMeter.Kosten_pro_Stunde.test', JSON.stringify(data), true);
          });
          
          

          Das json zeigt:

          [
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.00-01",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.01-02",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.02-03",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.03-04",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.04-05",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.05-06",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.07-08",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.08-09",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.09-10",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.10-11",
              "value": 5
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.11-12",
              "value": 7
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.12-13",
              "value": 8
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.13-14",
              "value": 6
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.14-15",
              "value": 6
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.15-16",
              "value": 6
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.16-17",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.17-18",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.18-19",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.19-20",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.20-21",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.21-22",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.22-23",
              "value": 0
            },
            {
              "label": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.23-00",
              "value": 0
            }
          ]
          
          paul53 1 Reply Last reply Reply Quote 0
          • paul53
            paul53 @bergjet last edited by paul53

            @bergjet sagte: Das json zeigt:

            ... und was soll es zeigen?
            Fall als "label" nur "00-01" usw., dann ändere die Schleife:

                dps.forEach(function(id) {
                    data.push({label: id.split('.')[4], value: getState(id).val});
                });
            
            bergjet 1 Reply Last reply Reply Quote 0
            • bergjet
              bergjet @paul53 last edited by

              @paul53 sagte in JSON Table erstellen:

              @bergjet sagte: Das json zeigt:

              ... und was soll es zeigen?
              Fall als "label" nur "00-01" usw., dann ändere die Schleife:

                  dps.forEach(function(id) {
                      data.push({label: id.split('.')[4], value: getState(id).val});
                  });
              

              Danke, jetzt wird mir nur noch 00-01 angezeigt.

              1 Reply Last reply Reply Quote 0
              • bergjet
                bergjet @paul53 last edited by

                @paul53
                Meine ursprüngliche Anwendung habe ich mit eurer Anleitung hinbekommen.
                Ich braucht nun einen Tipp für folgendes:
                Ich bräuchte folgende Datenpunkte pro Datensatz (5 Datensätze gibt es):
                Platz_1 Ort_1 Preis1 offen_1
                Platz_2 Ort_2 Preis2 offen_2
                Platz_3 Ort_3 Preis3 offen_3

                Bildschirm­foto 2022-11-10 um 14.26.01.png

                paul53 1 Reply Last reply Reply Quote 0
                • paul53
                  paul53 @bergjet last edited by paul53

                  @bergjet sagte: 5 Datensätze gibt es

                  Ansatz:

                  // IDs anpassen!
                  const idTable = '0_userdata.0.Spritpreise.Tabelle';
                  const inst = 'adaptername.0.Sprit_AT.Treffer_';
                  const ids = [
                      inst + '1.Preis_1',
                      inst + '2.Preis_2',
                      inst + '3.Preis_3',
                      inst + '4.Preis_4',
                      inst + '5.Preis_5'
                  ];
                  
                  var table = [];
                  var timer = null;
                  
                  function setTable() {
                      for(let i = 0; i < ids.length; i++) {
                          table[i] = {};
                          table[i].Strasse = getState(ids[i].replace('Preis', 'Strasse')).val;
                          table[i].Preis = getState(ids[i]).val;
                          table[i].offen = getState(ids[i].replace('Preis', 'offen')).val ? 'Ja' : 'Nein';
                      }
                      setState(idTable, JSON.stringify(table), true);
                  }
                  
                  setTable(); // Skriptstart
                  
                  on(ids, function() {
                      clearTimeout(timer);
                      timer = setTimeout(setTable, 200);
                  });
                  
                  bergjet 1 Reply Last reply Reply Quote 0
                  • bergjet
                    bergjet @paul53 last edited by

                    @paul53
                    Danke vielmals, funktioniert.
                    Noch eine Frage?

                    on(ids, function() {
                        clearTimeout(timer);
                        timer = setTimeout(setTable, 200);
                    });
                    

                    Ist es richtig, diese Funktion aktualisiert die Tabelle, wenn sich der json Wert ändert? Und was hat der Timer Wert 200 auf sich?

                    Mich würde noch interessieren, wie man z.B. den Wert

                    table[i].Strasse = getState(ids[i].replace('Preis', 'Strasse')).val;
                    

                    kürzen kann?
                    Fragen über Fragen.
                    Danke schon mal für die Mühe.

                    paul53 1 Reply Last reply Reply Quote 0
                    • paul53
                      paul53 @bergjet last edited by

                      @bergjet sagte: diese Funktion aktualisiert die Tabelle, wenn sich der json Wert ändert?

                      Sie aktualisiert die Tabelle, wenn sich ein Preis ändert.

                      @bergjet sagte in JSON Table erstellen:

                      was hat der Timer Wert 200 auf sich?

                      Der Adapter aktualisiert etliche Datenpunkte direkt hintereinander. Der Timeout sorgt dafür, dass die Tabelle erst aufgebaut wird, wenn der Adapter damit fertig ist.

                      @bergjet sagte in JSON Table erstellen:

                      kürzen kann?

                      Was kürzen?

                      bergjet 1 Reply Last reply Reply Quote 0
                      • bergjet
                        bergjet @paul53 last edited by

                        @paul53 sagte in JSON Table erstellen:

                        Was kürzen?

                        Das: table[i].Name = getState(ids[i].replace('Preis', 'Name')).val;
                        liefert mir: AVIA XPress (unser Service: Luft und Wasser)

                        Es würde genügen wenn AVIA XPress angezeigt wird.

                        paul53 1 Reply Last reply Reply Quote 0
                        • paul53
                          paul53 @bergjet last edited by paul53

                          @bergjet sagte: AVIA XPress (unser Service: Luft und Wasser)

                          Das ist doch bei jedem Tankstellennamen anders. Wo soll gekürzt werden?
                          Wenn nur bei diesem, dann versuche mal

                          table[i].Name = getState(ids[i].replace('Preis', 'Name')).val.replace('AVIA XPress (unser Service: Luft und Wasser)', 'AVIA XPress');
                          

                          oder

                          table[i].Name = getState(ids[i].replace('Preis', 'Name')).val.replace(' (unser Service: Luft und Wasser)', '');
                          
                          bergjet 1 Reply Last reply Reply Quote 0
                          • bergjet
                            bergjet @paul53 last edited by

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

                            paul53 1 Reply Last reply Reply Quote 0
                            • paul53
                              paul53 @bergjet last edited by paul53

                              @bergjet sagte: nur die ersten 10 Zeichen

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

                              Siehe Methoden.

                              1 Reply Last reply Reply Quote 1
                              • MIC1981
                                MIC1981 last edited by

                                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.

                                mickym 1 Reply Last reply Reply Quote 0
                                • mickym
                                  mickym Most Active @MIC1981 last edited by mickym

                                  gelöscht

                                  MIC1981 1 Reply Last reply Reply Quote 0
                                  • MIC1981
                                    MIC1981 @mickym last edited by

                                    @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 Reply Last reply Reply Quote 0
                                    • C
                                      Coffeelover last edited by

                                      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 Reply Last reply Reply Quote 0
                                      • First post
                                        Last post

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate
                                      FAQ Cloud / IOT
                                      HowTo: Node.js-Update
                                      HowTo: Backup/Restore
                                      Downloads
                                      BLOG

                                      976
                                      Online

                                      31.7k
                                      Users

                                      79.6k
                                      Topics

                                      1.3m
                                      Posts

                                      json string
                                      8
                                      45
                                      9819
                                      Loading More Posts
                                      • Oldest to Newest
                                      • Newest to Oldest
                                      • Most Votes
                                      Reply
                                      • Reply as topic
                                      Log in to reply
                                      Community
                                      Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                      The ioBroker Community 2014-2023
                                      logo