Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. JSON Table erstellen

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.2k

JSON Table erstellen

Scheduled Pinned Locked Moved ioBroker Allgemein
json string
45 Posts 8 Posters 12.2k Views 12 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • paul53P paul53

    @ofbeqnpolkkl6mby5e13 sagte: wenn "common.alias.id.read" vorhanden ist, "common.alias.id.read" statt "common.alias.id" verwendet wird?

    for(let i = 0; i < ids.length; i++) {
        table[i] = {};
        let common = getObject(ids[i]).common;
        table[i].Name = common.name;
        table[i].Wert = getState(ids[i]).val;
        table[i].Alias = common.alias.id.read ? common.alias.id.read : common.alias.id;
    }
    

    Man könnte auch typeof common.alias.id prüfen (String vs. Objekt).

    O Away
    O Away
    oFbEQnpoLKKl6mbY5e13
    wrote on last edited by
    #17

    @paul53

    Vielen Dank, funktioniert so! :+1:

    bergjetB 1 Reply Last reply
    0
    • bergjetB Offline
      bergjetB Offline
      bergjet
      wrote on last edited by bergjet
      #18

      @OLIVERIO Ich habe das Script mit meinen Datenpunkten angepasst und es lautet wie folgt:

      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({'title' : item,'value' : value.val})
          });
          setState('0_userdata.0.EnergyMeter.Kosten_pro_Stunde.jsontabelle', JSON.stringify(data), true);
      });
      
      

      Allerdings wird als Titel immer der Name des jeweiligen Datenpunktes
      z.B. "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.20-21" ausgegeben.

      homee, ioBroker, iMac, iPhone, Sonos, Alaxa

      OliverIOO 1 Reply Last reply
      0
      • O oFbEQnpoLKKl6mbY5e13

        @paul53

        Vielen Dank, funktioniert so! :+1:

        bergjetB Offline
        bergjetB Offline
        bergjet
        wrote on last edited by bergjet
        #19

        @ofbeqnpolkkl6mby5e13
        Wird bei dir auf der horizontalen Achse des Diagramms die Bezeichnung angezeigt?

        homee, ioBroker, iMac, iPhone, Sonos, Alaxa

        O 1 Reply Last reply
        0
        • bergjetB bergjet

          @OLIVERIO Ich habe das Script mit meinen Datenpunkten angepasst und es lautet wie folgt:

          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({'title' : item,'value' : value.val})
              });
              setState('0_userdata.0.EnergyMeter.Kosten_pro_Stunde.jsontabelle', JSON.stringify(data), true);
          });
          
          

          Allerdings wird als Titel immer der Name des jeweiligen Datenpunktes
          z.B. "0_userdata.0.EnergyMeter.Kosten_pro_Stunde.20-21" ausgegeben.

          OliverIOO Offline
          OliverIOO Offline
          OliverIO
          wrote on last edited by
          #20

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

          Meine Adapter und Widgets
          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
          Links im Profil

          bergjetB 2 Replies Last reply
          0
          • OliverIOO OliverIO

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

            bergjetB Offline
            bergjetB Offline
            bergjet
            wrote on last edited by
            #21

            @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

            homee, ioBroker, iMac, iPhone, Sonos, Alaxa

            OliverIOO 1 Reply Last reply
            0
            • bergjetB bergjet

              @ofbeqnpolkkl6mby5e13
              Wird bei dir auf der horizontalen Achse des Diagramms die Bezeichnung angezeigt?

              O Away
              O Away
              oFbEQnpoLKKl6mbY5e13
              wrote on last edited by
              #22

              @bergjet

              Ich nutze nur eine Tabelle zur Anzeige der Werte.

              1 Reply Last reply
              0
              • bergjetB bergjet

                @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

                OliverIOO Offline
                OliverIOO Offline
                OliverIO
                wrote on last edited by
                #23

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

                Meine Adapter und Widgets
                TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                Links im Profil

                bergjetB 1 Reply Last reply
                0
                • OliverIOO OliverIO

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

                  bergjetB Offline
                  bergjetB Offline
                  bergjet
                  wrote on last edited by
                  #24

                  @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
                    }
                  ]
                  

                  homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                  1 Reply Last reply
                  0
                  • OliverIOO OliverIO

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

                    bergjetB Offline
                    bergjetB Offline
                    bergjet
                    wrote on last edited by
                    #25

                    @oliverio sagte in JSON Table erstellen:

                    Welches Diagramm?

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

                    homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                    OliverIOO 1 Reply Last reply
                    0
                    • bergjetB bergjet

                      @oliverio sagte in JSON Table erstellen:

                      Welches Diagramm?

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

                      OliverIOO Offline
                      OliverIOO Offline
                      OliverIO
                      wrote on last edited by
                      #26

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

                      Meine Adapter und Widgets
                      TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                      Links im Profil

                      bergjetB 1 Reply Last reply
                      0
                      • OliverIOO OliverIO

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

                        bergjetB Offline
                        bergjetB Offline
                        bergjet
                        wrote on last edited by
                        #27

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

                        homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                        1 Reply Last reply
                        0
                        • OliverIOO Offline
                          OliverIOO Offline
                          OliverIO
                          wrote on last edited by OliverIO
                          #28

                          @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

                          Meine Adapter und Widgets
                          TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                          Links im Profil

                          bergjetB OliverIOO 2 Replies Last reply
                          0
                          • OliverIOO 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

                            bergjetB Offline
                            bergjetB Offline
                            bergjet
                            wrote on last edited by
                            #29

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

                            homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                            1 Reply Last reply
                            0
                            • OliverIOO 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

                              OliverIOO Offline
                              OliverIOO Offline
                              OliverIO
                              wrote on last edited by
                              #30

                              @bergjet

                              @oliverio sagte in JSON Table erstellen:

                              das es label und nicht title heißen muss

                              Meine Adapter und Widgets
                              TVProgram, SqueezeboxRPC, OpenLiga, RSSFeed, MyTime,, pi-hole2, vis-json-template, skiinfo, vis-mapwidgets, vis-2-widgets-rssfeed
                              Links im Profil

                              bergjetB 1 Reply Last reply
                              0
                              • OliverIOO OliverIO

                                @bergjet

                                @oliverio sagte in JSON Table erstellen:

                                das es label und nicht title heißen muss

                                bergjetB Offline
                                bergjetB Offline
                                bergjet
                                wrote on last edited by
                                #31

                                @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
                                  }
                                ]
                                

                                homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                paul53P 1 Reply Last reply
                                0
                                • bergjetB bergjet

                                  @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
                                    }
                                  ]
                                  
                                  paul53P Offline
                                  paul53P Offline
                                  paul53
                                  wrote on last edited by paul53
                                  #32

                                  @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});
                                      });
                                  

                                  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

                                  bergjetB 1 Reply Last reply
                                  0
                                  • paul53P 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});
                                        });
                                    
                                    bergjetB Offline
                                    bergjetB Offline
                                    bergjet
                                    wrote on last edited by
                                    #33

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

                                    homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                    1 Reply Last reply
                                    0
                                    • paul53P paul53

                                      @michihorn sagte:

                                      Spalte 1 der DP und Spalte 2 der Wert stehen.

                                      Versuche es mal so:

                                      const idTable = '...'; // ID JSON-Tabelle
                                      const ids = ['hm-rega.0.39564','hm-rega.0.37206','hm-rega.0.31888','hm-rega.0.37157','javascript.0.ccu.cpuFrequency']; 
                                       
                                      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);
                                      });
                                      
                                      bergjetB Offline
                                      bergjetB Offline
                                      bergjet
                                      wrote on last edited by
                                      #34

                                      @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

                                      homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                      paul53P 1 Reply Last reply
                                      0
                                      • bergjetB bergjet

                                        @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

                                        paul53P Offline
                                        paul53P Offline
                                        paul53
                                        wrote on last edited by paul53
                                        #35

                                        @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);
                                        });
                                        

                                        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

                                        bergjetB 1 Reply Last reply
                                        0
                                        • paul53P 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);
                                          });
                                          
                                          bergjetB Offline
                                          bergjetB Offline
                                          bergjet
                                          wrote on last edited by
                                          #36

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

                                          homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                          paul53P 1 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

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

                                          384

                                          Online

                                          32.6k

                                          Users

                                          82.2k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe