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

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

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.
  • M Offline
    M Offline
    michihorn
    schrieb am zuletzt editiert von michihorn
    #1

    Ich möchte für ein Widget vorhandene Datenpunkte in einen JSON String umwandeln. Wie geht das?

    1. hm-rega.0.39564 UpTime Wert der im DP steht 6T 00:26
    2. hm-rega.0.37206 Temperatur Raspberry Wert der im DP steht 43,8
    3. hm-rega.0.31888 DutyCycle Wert 13%
    4. hm-rega.0.37157 WatchDog Wert ist true/false
    5. javascript.0.ccu.cpuFrequency Wert 1200

    Ich habe mir mal in den Objekten die RAW Darstellung angeschaut.

    {
      "from": "system.adapter.hm-rega.0",
      "user": "system.user.admin",
      "ts": 1589545028808,
      "common": {
        "name": "Temperatur Raspberry Zahl",
        "type": "number",
        "role": "state",
        "desc": "Temperatur Wert",
        "min": 0,
        "max": 100,
        "read": true,
        "write": true
      },
      "native": {
        "Name": "Temperatur Raspberry Zahl",
        "TypeName": "VARDP",
        "DPInfo": "Temperatur Wert",
        "ValueUnit": "",
        "ValueList": "",
        "ValueMin": 0,
        "ValueMax": 100,
        "ValueType": 4,
        "ValueSubType": 0
      },
      "acl": {
        "object": 1636,
        "owner": "system.user.admin",
        "ownerGroup": "system.group.administrator",
        "state": 1636
      },
      "_id": "hm-rega.0.37205",
      "type": "state"
    }
    

    Die Schreibweise soll Spalte 1 der DP und Spalte 2 der Wert stehen.

    Gruß
    Michael

    paul53P 1 Antwort Letzte Antwort
    0
    • M michihorn

      Ich möchte für ein Widget vorhandene Datenpunkte in einen JSON String umwandeln. Wie geht das?

      1. hm-rega.0.39564 UpTime Wert der im DP steht 6T 00:26
      2. hm-rega.0.37206 Temperatur Raspberry Wert der im DP steht 43,8
      3. hm-rega.0.31888 DutyCycle Wert 13%
      4. hm-rega.0.37157 WatchDog Wert ist true/false
      5. javascript.0.ccu.cpuFrequency Wert 1200

      Ich habe mir mal in den Objekten die RAW Darstellung angeschaut.

      {
        "from": "system.adapter.hm-rega.0",
        "user": "system.user.admin",
        "ts": 1589545028808,
        "common": {
          "name": "Temperatur Raspberry Zahl",
          "type": "number",
          "role": "state",
          "desc": "Temperatur Wert",
          "min": 0,
          "max": 100,
          "read": true,
          "write": true
        },
        "native": {
          "Name": "Temperatur Raspberry Zahl",
          "TypeName": "VARDP",
          "DPInfo": "Temperatur Wert",
          "ValueUnit": "",
          "ValueList": "",
          "ValueMin": 0,
          "ValueMax": 100,
          "ValueType": 4,
          "ValueSubType": 0
        },
        "acl": {
          "object": 1636,
          "owner": "system.user.admin",
          "ownerGroup": "system.group.administrator",
          "state": 1636
        },
        "_id": "hm-rega.0.37205",
        "type": "state"
      }
      

      Die Schreibweise soll Spalte 1 der DP und Spalte 2 der Wert stehen.

      Gruß
      Michael

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

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

      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

      O bergjetB 2 Antworten Letzte Antwort
      0
      • OliverIOO Offline
        OliverIOO Offline
        OliverIO
        schrieb am zuletzt editiert von OliverIO
        #3

        Mein vorschlag würde so aussehen. aber sehr ähnlich zum gerade geposteten.
        vorteil von der vorherigen Lösung ist, das er sich einen einheitlichen Namen aus den objektdaten holt

        var dps =[
        "javascript.0.dp1",
        "javascript.0.dp2",
        "javascript.0.dp3"
        ];
        
        on({id: dps, change: 'ne'}, function (dp) {
            var data = [];
            dps.forEach( function(item) {
                var value = getState(item);
                data.push({'title' : item,'value' : value.val})
            });
            setState('javascript.0.jsontable', JSON.stringify(data), true);
        });
        

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

        1 Antwort Letzte Antwort
        0
        • M Offline
          M Offline
          michihorn
          schrieb am zuletzt editiert von
          #4

          Vielen Dank ihr beiden, für die schnelle Antwort.
          Ich fürchte ich bin Überfordert.
          Hintergrund der Aufgabe ist, ich möchte folgendes Widget füllen:

          [{"tpl":"tplVis-materialdesign-Table","data":{"oid":"","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","countCols":"4","tableLayout":"card","showHeader":false,"headerTextSize":"15","textAlign0":"left","textAlign1":"left","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"label0":"UpTime","label1":"CPU Freq.","textAlign2":"left","label2":"CPU Takt","textAlign3":"right","label3":"DutyCycle","textSize0":"12","textSize1":"20","textSize2":"15","textSize3":"11","rowHeight":"25","padding_left1":"0","padding_left2":"0","padding_left3":"0","padding_right0":"0","padding_right1":"-3","padding_right2":"","padding_right3":"","textAlign4":"center","padding_left4":"0","padding_right4":"0","label4":" ","headerRowHeight":"1","showColumn0":true,"showColumn1":true,"showColumn2":"true","showColumn3":false,"fontFamily0":"RobotoCondensed-Regular","fontFamily1":"RobotoCondensed-Regular","fontFamily2":"RobotoCondensed-Regular","fontFamily3":"RobotoCondensed-Regular","colorHeaderRowBackground":"#44739e","colorHeaderRowText":"#ffffff","headerFontFamily":"RobotoCondensed-Regular","textColor0":"","textColor1":"#44739e","colType0":"image","colType1":"text","colType2":"text","colType3":"text","imageHeight0":"33","prefix0":"","suffix0":"</div>","padding_left0":"3","prefix1":"","suffix1":"<font></a>","showColumn4":false,"colType4":"text","dataJson":"","sortKey0":"","showColumn5":false,"colType5":"text","textAlign5":"center","showColumn6":false,"colType6":"text","textAlign6":"center","sortKey2":"","columnWidth0":"-15","columnWidth1":"17","imageSize2":"-2"},"style":{"left":"479px","top":"304px","width":"542px","height":"326px","overflow-y":""},"widgetSet":"materialdesign"}]
          

          Gruß
          Michael

          paul53P 1 Antwort Letzte Antwort
          0
          • M michihorn

            Vielen Dank ihr beiden, für die schnelle Antwort.
            Ich fürchte ich bin Überfordert.
            Hintergrund der Aufgabe ist, ich möchte folgendes Widget füllen:

            [{"tpl":"tplVis-materialdesign-Table","data":{"oid":"","g_fixed":false,"g_visibility":false,"g_css_font_text":false,"g_css_background":false,"g_css_shadow_padding":false,"g_css_border":false,"g_gestures":false,"g_signals":false,"g_last_change":false,"visibility-cond":"==","visibility-val":1,"visibility-groups-action":"hide","countCols":"4","tableLayout":"card","showHeader":false,"headerTextSize":"15","textAlign0":"left","textAlign1":"left","signals-cond-0":"==","signals-val-0":true,"signals-icon-0":"/vis/signals/lowbattery.png","signals-icon-size-0":0,"signals-blink-0":false,"signals-horz-0":0,"signals-vert-0":0,"signals-hide-edit-0":false,"signals-cond-1":"==","signals-val-1":true,"signals-icon-1":"/vis/signals/lowbattery.png","signals-icon-size-1":0,"signals-blink-1":false,"signals-horz-1":0,"signals-vert-1":0,"signals-hide-edit-1":false,"signals-cond-2":"==","signals-val-2":true,"signals-icon-2":"/vis/signals/lowbattery.png","signals-icon-size-2":0,"signals-blink-2":false,"signals-horz-2":0,"signals-vert-2":0,"signals-hide-edit-2":false,"lc-type":"last-change","lc-is-interval":true,"lc-is-moment":false,"lc-format":"","lc-position-vert":"top","lc-position-horz":"right","lc-offset-vert":0,"lc-offset-horz":0,"lc-font-size":"12px","lc-font-family":"","lc-font-style":"","lc-bkg-color":"","lc-color":"","lc-border-width":"0","lc-border-style":"","lc-border-color":"","lc-border-radius":10,"lc-zindex":0,"label0":"UpTime","label1":"CPU Freq.","textAlign2":"left","label2":"CPU Takt","textAlign3":"right","label3":"DutyCycle","textSize0":"12","textSize1":"20","textSize2":"15","textSize3":"11","rowHeight":"25","padding_left1":"0","padding_left2":"0","padding_left3":"0","padding_right0":"0","padding_right1":"-3","padding_right2":"","padding_right3":"","textAlign4":"center","padding_left4":"0","padding_right4":"0","label4":" ","headerRowHeight":"1","showColumn0":true,"showColumn1":true,"showColumn2":"true","showColumn3":false,"fontFamily0":"RobotoCondensed-Regular","fontFamily1":"RobotoCondensed-Regular","fontFamily2":"RobotoCondensed-Regular","fontFamily3":"RobotoCondensed-Regular","colorHeaderRowBackground":"#44739e","colorHeaderRowText":"#ffffff","headerFontFamily":"RobotoCondensed-Regular","textColor0":"","textColor1":"#44739e","colType0":"image","colType1":"text","colType2":"text","colType3":"text","imageHeight0":"33","prefix0":"","suffix0":"</div>","padding_left0":"3","prefix1":"","suffix1":"<font></a>","showColumn4":false,"colType4":"text","dataJson":"","sortKey0":"","showColumn5":false,"colType5":"text","textAlign5":"center","showColumn6":false,"colType6":"text","textAlign6":"center","sortKey2":"","columnWidth0":"-15","columnWidth1":"17","imageSize2":"-2"},"style":{"left":"479px","top":"304px","width":"542px","height":"326px","overflow-y":""},"widgetSet":"materialdesign"}]
            

            Gruß
            Michael

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

            @michihorn sagte:

            Ich fürchte ich bin Überfordert.

            Du brauchst doch nur in der ersten Zeile die ID für den Datenpunkt (Typ: Zeichenkette), der die JSON-Tabelle enthalten soll, eintragen. Der Rest sollte passen.

            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

            M 1 Antwort Letzte Antwort
            0
            • paul53P paul53

              @michihorn sagte:

              Ich fürchte ich bin Überfordert.

              Du brauchst doch nur in der ersten Zeile die ID für den Datenpunkt (Typ: Zeichenkette), der die JSON-Tabelle enthalten soll, eintragen. Der Rest sollte passen.

              M Offline
              M Offline
              michihorn
              schrieb am zuletzt editiert von
              #6

              @paul53 Der Datenpunkt sieht so aus. Es passiert aber nix

              {
                "common": {
                  "name": "javascript.0.table.Paul53.jsontable2",
                  "role": "state",
                  "type": "string"
                },
                "native": {},
                "type": "state",
                "from": "system.adapter.javascript.0",
                "user": "system.user.admin",
                "ts": 1589993623009,
                "_id": "javascript.0.table.Paul53.jsontable2",
                "acl": {
                  "object": 1636,
                  "state": 1636,
                  "owner": "system.user.admin",
                  "ownerGroup": "system.group.administrator"
                }
              }
              

              Inhaltlich ist der DP leer
              Michael

              M 1 Antwort Letzte Antwort
              0
              • M michihorn

                @paul53 Der Datenpunkt sieht so aus. Es passiert aber nix

                {
                  "common": {
                    "name": "javascript.0.table.Paul53.jsontable2",
                    "role": "state",
                    "type": "string"
                  },
                  "native": {},
                  "type": "state",
                  "from": "system.adapter.javascript.0",
                  "user": "system.user.admin",
                  "ts": 1589993623009,
                  "_id": "javascript.0.table.Paul53.jsontable2",
                  "acl": {
                    "object": 1636,
                    "state": 1636,
                    "owner": "system.user.admin",
                    "ownerGroup": "system.group.administrator"
                  }
                }
                

                Inhaltlich ist der DP leer
                Michael

                M Offline
                M Offline
                michihorn
                schrieb am zuletzt editiert von michihorn
                #7

                @michihorn Sorry jetzt steht was im DP. Hat wohl etwas gedauert.

                [{"Name":"Uptime","Wert":"6T 11:18"},{"Name":"Temperatur Raspberry","Wert":"48.30"},{"Name":"DutyCycle","Wert":27},{"Name":"WatchDog-Alarm","Wert":false},{"Name":"javascript.0.ccu.cpuFrequency","Wert":600}]

                Das Standard Widget funktioniert, nur das Material Design Widget zeigt nichts an.
                @paul53 @OliverIO : Achja und vielen Dank

                paul53P OliverIOO 2 Antworten Letzte Antwort
                0
                • M michihorn

                  @michihorn Sorry jetzt steht was im DP. Hat wohl etwas gedauert.

                  [{"Name":"Uptime","Wert":"6T 11:18"},{"Name":"Temperatur Raspberry","Wert":"48.30"},{"Name":"DutyCycle","Wert":27},{"Name":"WatchDog-Alarm","Wert":false},{"Name":"javascript.0.ccu.cpuFrequency","Wert":600}]

                  Das Standard Widget funktioniert, nur das Material Design Widget zeigt nichts an.
                  @paul53 @OliverIO : Achja und vielen Dank

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

                  @michihorn sagte:

                  Das Standard Widget funktioniert, nur das Material Design Widget zeigt nichts an.

                  Welches JSON-Format braucht das Material Design Widget ?

                  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 Antwort Letzte Antwort
                  0
                  • M michihorn

                    @michihorn Sorry jetzt steht was im DP. Hat wohl etwas gedauert.

                    [{"Name":"Uptime","Wert":"6T 11:18"},{"Name":"Temperatur Raspberry","Wert":"48.30"},{"Name":"DutyCycle","Wert":27},{"Name":"WatchDog-Alarm","Wert":false},{"Name":"javascript.0.ccu.cpuFrequency","Wert":600}]

                    Das Standard Widget funktioniert, nur das Material Design Widget zeigt nichts an.
                    @paul53 @OliverIO : Achja und vielen Dank

                    OliverIOO Offline
                    OliverIOO Offline
                    OliverIO
                    schrieb am zuletzt editiert von
                    #9

                    @michihorn sagte in JSON Table erstellen:

                    [{"Name":"Uptime","Wert":"6T 11:18"},{"Name":"Temperatur Raspberry","Wert":"48.30"},{"Name":"DutyCycle","Wert":27},{"Name":"WatchDog-Alarm","Wert":false},{"Name":"javascript.0.ccu.cpuFrequency","Wert":600}]

                    Ich habe genau dieses JSON in das widget eingetragen (allerdings ohne Datenpunkt.

                    Bei mir zeigt es die Daten an. Im gegensatz zum originalen JSON Table widget des iobrokers kann man die Spaltenköpfe im widget selber benennen.

                    @paul53
                    Das notwendige Format ist Array of Objects für die Tabelle, ein Object für eine Zeile, jedes Property des Objekts ist dann eine Spalte. Propertynamen sind egal, die müssen im widget selbst benannt werden.

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

                    M 1 Antwort Letzte Antwort
                    0
                    • OliverIOO OliverIO

                      @michihorn sagte in JSON Table erstellen:

                      [{"Name":"Uptime","Wert":"6T 11:18"},{"Name":"Temperatur Raspberry","Wert":"48.30"},{"Name":"DutyCycle","Wert":27},{"Name":"WatchDog-Alarm","Wert":false},{"Name":"javascript.0.ccu.cpuFrequency","Wert":600}]

                      Ich habe genau dieses JSON in das widget eingetragen (allerdings ohne Datenpunkt.

                      Bei mir zeigt es die Daten an. Im gegensatz zum originalen JSON Table widget des iobrokers kann man die Spaltenköpfe im widget selber benennen.

                      @paul53
                      Das notwendige Format ist Array of Objects für die Tabelle, ein Object für eine Zeile, jedes Property des Objekts ist dann eine Spalte. Propertynamen sind egal, die müssen im widget selbst benannt werden.

                      M Offline
                      M Offline
                      michihorn
                      schrieb am zuletzt editiert von
                      #10

                      @OliverIO @paul53 Ich habe heute morgen ein VIS Downgrade 1.2.6 auf 1.2.4 gemacht , nun sehe ich auch im Material Widget Daten. Nur wie kann ich die Daten aktualisieren.
                      Habe mal versucht dem Script eine Schedule hinzu zufügen, aber aktuell hat sich nix getan
                      Das Script sieht jetzt so aus.

                      //createState("javascript.0.table.Paul53.jsontable2", {type: "string" });
                      const idTable = 'javascript.0.table.Paul53.jsontable2'; // 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 = [];
                      schedule("* * * * *", function () { 
                      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);
                      });
                      });
                      

                      Gruß Michael

                      OliverIOO paul53P 2 Antworten Letzte Antwort
                      0
                      • M michihorn

                        @OliverIO @paul53 Ich habe heute morgen ein VIS Downgrade 1.2.6 auf 1.2.4 gemacht , nun sehe ich auch im Material Widget Daten. Nur wie kann ich die Daten aktualisieren.
                        Habe mal versucht dem Script eine Schedule hinzu zufügen, aber aktuell hat sich nix getan
                        Das Script sieht jetzt so aus.

                        //createState("javascript.0.table.Paul53.jsontable2", {type: "string" });
                        const idTable = 'javascript.0.table.Paul53.jsontable2'; // 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 = [];
                        schedule("* * * * *", function () { 
                        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);
                        });
                        });
                        

                        Gruß Michael

                        OliverIOO Offline
                        OliverIOO Offline
                        OliverIO
                        schrieb am zuletzt editiert von
                        #11

                        @michihorn
                        Das on
                        Sorgt dafür, das die angegebenen datenpunkte überwacht werden und jedesmal wenn sich einer der datenpunkte ändert der Tabellen datenpunkt neu geschrieben wird.

                        Also kein schedule hinzufügen, sondern einfach das Skript starten

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

                        M 1 Antwort Letzte Antwort
                        0
                        • OliverIOO OliverIO

                          @michihorn
                          Das on
                          Sorgt dafür, das die angegebenen datenpunkte überwacht werden und jedesmal wenn sich einer der datenpunkte ändert der Tabellen datenpunkt neu geschrieben wird.

                          Also kein schedule hinzufügen, sondern einfach das Skript starten

                          M Offline
                          M Offline
                          michihorn
                          schrieb am zuletzt editiert von michihorn
                          #12

                          @OliverIO Guten Morgen, das Script läuft, Werte werden nicht aktualisiert, daher hatte ich den Timer eingebaut
                          Ich habe das Script jetzt auf eine andere Instanz gelegt, werde es mal beobachten.
                          Gruß
                          Michael

                          OliverIOO 1 Antwort Letzte Antwort
                          0
                          • M michihorn

                            @OliverIO Guten Morgen, das Script läuft, Werte werden nicht aktualisiert, daher hatte ich den Timer eingebaut
                            Ich habe das Script jetzt auf eine andere Instanz gelegt, werde es mal beobachten.
                            Gruß
                            Michael

                            OliverIOO Offline
                            OliverIOO Offline
                            OliverIO
                            schrieb am zuletzt editiert von
                            #13

                            @michihorn
                            Füge der Auflistung doch einen eigenen Datenpunkt hinzuden du selbst verändern kannst. Dann kannst du besser testen

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

                            1 Antwort Letzte Antwort
                            0
                            • M michihorn

                              @OliverIO @paul53 Ich habe heute morgen ein VIS Downgrade 1.2.6 auf 1.2.4 gemacht , nun sehe ich auch im Material Widget Daten. Nur wie kann ich die Daten aktualisieren.
                              Habe mal versucht dem Script eine Schedule hinzu zufügen, aber aktuell hat sich nix getan
                              Das Script sieht jetzt so aus.

                              //createState("javascript.0.table.Paul53.jsontable2", {type: "string" });
                              const idTable = 'javascript.0.table.Paul53.jsontable2'; // 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 = [];
                              schedule("* * * * *", function () { 
                              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);
                              });
                              });
                              

                              Gruß Michael

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

                              @michihorn sagte:

                              Das Script sieht jetzt so aus.

                              So werden jede Minute 5 weitere Trigger hinzugefügt bis der RAM überläuft.

                              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 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);
                                });
                                
                                O Offline
                                O Offline
                                oFbEQnpoLKKl6mbY5e13
                                schrieb am zuletzt editiert von oFbEQnpoLKKl6mbY5e13
                                #15

                                @paul53 sagte in JSON Table erstellen:

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

                                Vielen Dank für deine Vorlage, die ich trotz fehlender JS-Kenntnisse leicht auf meine Bedürfnisse anpassen konnte:

                                const idTable = '0_userdata.0.Haus.VIS.TEst'; // ID JSON-Tabelle
                                
                                const ids = Array.prototype.slice.apply($("state[id='alias.0.*.switch_on']")); 
                                
                                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;
                                
                                    table[i].Alias = getObject(ids[i]).common.alias.id;
                                
                                }
                                
                                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);
                                
                                });
                                
                                

                                Leider ergibt sich das Problem, dass bei allen Alias-Datenpunkten mit getrennten Lese-/Schreib-IDs nur "[object Object]" für den Wert "Alias" (common.alias.id) im JSON steht, da hier noch "common.alias.id.read" und "common.alias.id.write" existieren.

                                Wie kann man das so lösen, dass wenn "common.alias.id.read" vorhanden ist, "common.alias.id.read" statt "common.alias.id" verwendet wird?

                                paul53P 1 Antwort Letzte Antwort
                                0
                                • O oFbEQnpoLKKl6mbY5e13

                                  @paul53 sagte in JSON Table erstellen:

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

                                  Vielen Dank für deine Vorlage, die ich trotz fehlender JS-Kenntnisse leicht auf meine Bedürfnisse anpassen konnte:

                                  const idTable = '0_userdata.0.Haus.VIS.TEst'; // ID JSON-Tabelle
                                  
                                  const ids = Array.prototype.slice.apply($("state[id='alias.0.*.switch_on']")); 
                                  
                                  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;
                                  
                                      table[i].Alias = getObject(ids[i]).common.alias.id;
                                  
                                  }
                                  
                                  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);
                                  
                                  });
                                  
                                  

                                  Leider ergibt sich das Problem, dass bei allen Alias-Datenpunkten mit getrennten Lese-/Schreib-IDs nur "[object Object]" für den Wert "Alias" (common.alias.id) im JSON steht, da hier noch "common.alias.id.read" und "common.alias.id.write" existieren.

                                  Wie kann man das so lösen, dass wenn "common.alias.id.read" vorhanden ist, "common.alias.id.read" statt "common.alias.id" verwendet wird?

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

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

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

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

                                  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

                                  O 1 Antwort Letzte Antwort
                                  1
                                  • paul53P paul53

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

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

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

                                    O Offline
                                    O Offline
                                    oFbEQnpoLKKl6mbY5e13
                                    schrieb am zuletzt editiert von
                                    #17

                                    @paul53

                                    Vielen Dank, funktioniert so! :+1:

                                    bergjetB 1 Antwort Letzte Antwort
                                    0
                                    • bergjetB Offline
                                      bergjetB Offline
                                      bergjet
                                      schrieb am zuletzt editiert von bergjet
                                      #18

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

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

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

                                      homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                      OliverIOO 1 Antwort Letzte Antwort
                                      0
                                      • O oFbEQnpoLKKl6mbY5e13

                                        @paul53

                                        Vielen Dank, funktioniert so! :+1:

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

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

                                        homee, ioBroker, iMac, iPhone, Sonos, Alaxa

                                        O 1 Antwort Letzte Antwort
                                        0
                                        • bergjetB bergjet

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

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

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

                                          OliverIOO Offline
                                          OliverIOO Offline
                                          OliverIO
                                          schrieb am zuletzt editiert von
                                          #20

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

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

                                          bergjetB 2 Antworten 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

                                          336

                                          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