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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.1k

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.
  • 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
                          • 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
                            wrote on last edited by
                            #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 Reply Last reply
                            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
                              wrote on last edited by
                              #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 Reply Last reply
                              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
                                wrote on last edited by 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 Reply Last reply
                                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
                                  wrote on last edited by
                                  #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 Reply Last reply
                                  0
                                  • bergjetB bergjet

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

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

                                    @bergjet sagte: nur die ersten 10 Zeichen

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

                                    Siehe Methoden.

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

                                    1 Reply Last reply
                                    1
                                    • MIC1981M Offline
                                      MIC1981M Offline
                                      MIC1981
                                      wrote on last edited by
                                      #42

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

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

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

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

                                      Wie bekomme ich die eckigen Klammern weg? Danke schonmal.

                                      mickymM 1 Reply Last reply
                                      0
                                      • MIC1981M MIC1981

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

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

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

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

                                        Wie bekomme ich die eckigen Klammern weg? Danke schonmal.

                                        mickymM Online
                                        mickymM Online
                                        mickym
                                        Most Active
                                        wrote on last edited by mickym
                                        #43

                                        gelöscht

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

                                        MIC1981M 1 Reply Last reply
                                        0
                                        • mickymM mickym

                                          gelöscht

                                          MIC1981M Offline
                                          MIC1981M Offline
                                          MIC1981
                                          wrote on last edited by
                                          #44

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

                                          1 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

                                          745

                                          Online

                                          32.6k

                                          Users

                                          82.1k

                                          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