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

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    JSON Table erstellen

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

      @bergjet
      ich habe es gerade bei mir nochmal ausprobiert.
      bei mir funktioniert das.
      zeig bitte mal den kompletten inhalt des datenpunkts jsontabelle

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

        @oliverio
        Ich habe jetzt dieses Script:

        const idTable = '0_userdata.0.EnergyMeter.Kosten_pro_Stunde.jsontabelle'; // ID JSON-Tabelle
        const ids = [
        '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.06-07',
        '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'
        ]; 
         
        var table = [];
        for(let i = 0; i < ids.length; i++) {
            table[i] = {};
            table[i].title = getObject(ids[i]).common.name;
            table[i].value = 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);
        });
        

        Da stimmt es nun. Allerdings wird mir im Diagramm der Titel nicht angezeigt.

        jsontabelle

        [
          {
            "title": "00-01",
            "value": 0
          },
          {
            "title": "01-02",
            "value": 0
          },
          {
            "title": "02-03",
            "value": 0
          },
          {
            "title": "03-04",
            "value": 0
          },
          {
            "title": "04-05",
            "value": 0
          },
          {
            "title": "05-06",
            "value": 0
          },
          {
            "title": "06-07",
            "value": 0
          },
          {
            "title": "07-08",
            "value": 0
          },
          {
            "title": "08-09",
            "value": 0
          },
          {
            "title": "09-10",
            "value": 0
          },
          {
            "title": "10-11",
            "value": 0
          },
          {
            "title": "11-12",
            "value": 7
          },
          {
            "title": "12-13",
            "value": 0
          },
          {
            "title": "13-14",
            "value": 0
          },
          {
            "title": "14-15",
            "value": 0
          },
          {
            "title": "15-16",
            "value": 0
          },
          {
            "title": "16-17",
            "value": 0
          },
          {
            "title": "17-18",
            "value": 0
          },
          {
            "title": "18-19",
            "value": 0
          },
          {
            "title": "19-20",
            "value": 0
          },
          {
            "title": "20-21",
            "value": 0
          },
          {
            "title": "21-22",
            "value": 0
          },
          {
            "title": "22-23",
            "value": 0
          }
        ]
        

        Bildschirm­foto 2022-11-07 um 12.53.19.png

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

          @bergjet

          Ich nutze nur eine Tabelle zur Anzeige der Werte.

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

            @bergjet sagte in JSON Table erstellen:

            Diagramm

            Welches Diagramm?
            Hier geht es doch darum ein json aufzubauen, welches über das
            widget json table angezeigt werden kann.

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

              @oliverio sagte in JSON Table erstellen:

              zeig bitte mal den kompletten inhalt des datenpunkts jsontabelle

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

                @oliverio sagte in JSON Table erstellen:

                Welches Diagramm?

                Das ist das Diagramm Widget in VIS. Greift auch auf die json Tabelle zu.

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

                  @bergjet
                  in welchem adapter ist das enthalten? Im Standard habe ich das nicht.
                  bzw. finde es nicht wenn ich in die Suchbox diagram eingebe

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

                    @oliverio sagte in JSON Table erstellen:

                    in welchem adapter ist das enthalten?

                    vis-materialdesign

                    Vielleicht hängt das zusammen, weil als Titel in der jsontabelle "title": "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.03-04" angezeigt wird.

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

                      @bergjet sagte in JSON Table erstellen:

                      vis-materialdesign

                      hast du die dokumentation dazu gelesen?
                      https://github.com/Scrounger/ioBroker.vis-materialdesign#charts
                      evtl liegt es auch daran, das es label und nicht title heißen muss.
                      die widgets können nicht hellsehen

                      leider hast du wieder nicht verraten, welches der diagram widgets es ist.
                      es wird langsam anstrengend

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

                                            Support us

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

                                            734
                                            Online

                                            31.7k
                                            Users

                                            79.9k
                                            Topics

                                            1.3m
                                            Posts

                                            json string
                                            8
                                            45
                                            9972
                                            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