Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

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

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    22
    1
    1.2k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.5k

JSON Table erstellen

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
json string
45 Beiträge 8 Kommentatoren 12.0k Aufrufe 11 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • 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
    schrieb am zuletzt editiert von
    #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 Antwort Letzte Antwort
    0
    • bergjetB bergjet

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

      O Abwesend
      O Abwesend
      oFbEQnpoLKKl6mbY5e13
      schrieb am zuletzt editiert von
      #22

      @bergjet

      Ich nutze nur eine Tabelle zur Anzeige der Werte.

      1 Antwort Letzte Antwort
      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
        schrieb am zuletzt editiert von
        #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 Antwort Letzte Antwort
        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
          schrieb am zuletzt editiert von
          #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 Antwort Letzte Antwort
          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
            schrieb am zuletzt editiert von
            #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 Antwort Letzte Antwort
            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
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              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
                schrieb am zuletzt editiert von
                #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 Antwort Letzte Antwort
                0
                • OliverIOO Offline
                  OliverIOO Offline
                  OliverIO
                  schrieb am zuletzt editiert von 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 Antworten Letzte Antwort
                  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
                    schrieb am zuletzt editiert von
                    #29

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

                    homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                    1 Antwort Letzte Antwort
                    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
                      schrieb am zuletzt editiert von
                      #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 Antwort Letzte Antwort
                      0
                      • OliverIOO OliverIO

                        @bergjet

                        @oliverio sagte in JSON Table erstellen:

                        das es label und nicht title heißen muss

                        bergjetB Offline
                        bergjetB Offline
                        bergjet
                        schrieb am zuletzt editiert von
                        #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 Antwort Letzte Antwort
                        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
                          schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                          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
                            schrieb am zuletzt editiert von
                            #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 Antwort Letzte Antwort
                            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
                              schrieb am zuletzt editiert von
                              #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 Antwort Letzte Antwort
                              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
                                schrieb am zuletzt editiert von 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 Antwort Letzte Antwort
                                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
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  0
                                  • bergjetB bergjet

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

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

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

                                    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 Antwort Letzte Antwort
                                    0
                                    • paul53P paul53

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

                                      bergjetB Offline
                                      bergjetB Offline
                                      bergjet
                                      schrieb am zuletzt editiert von
                                      #38

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

                                      homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                      paul53P 1 Antwort Letzte Antwort
                                      0
                                      • bergjetB bergjet

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

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

                                        @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)', '');
                                        

                                        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 Antwort Letzte Antwort
                                        0
                                        • paul53P 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)', '');
                                          
                                          bergjetB Offline
                                          bergjetB Offline
                                          bergjet
                                          schrieb am zuletzt editiert von
                                          #40

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

                                          homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                          paul53P 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

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

                                          642

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe