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. Einsteigerfragen
  4. json einfach Filtern (VIS)

NEWS

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

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

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    25
    1
    2.0k

json einfach Filtern (VIS)

Geplant Angeheftet Gesperrt Verschoben Einsteigerfragen
23 Beiträge 7 Kommentatoren 1.8k Aufrufe 4 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.
  • Ro75R Ro75

    @sirpritz

    So mache ich es:

    createState('0_userdata.0.Alexa.ToDoListe', "[]", {read: true, write: true, desc: "JSON String", type: "string", def: "[]"});
    
    function Einkaufsliste() {
        setTimeout(function(){
            var vEString='';
            let ListeEinkauf = [];
            $('alexa2.0.Lists.SHOPPING_LIST.items.*.value').each(function(id, i) {
                if(getState(id.replace("value","completed")).val === false) {
                    vEString ='FF'; //dient einfach nur als merkmal, das die Liste nicht leer ist
                    ListeEinkauf.push({
                        Artikel: getState(id).val
                    })
                }
            });
            if(vEString == '') {
                ListeEinkauf.push({
                    Artikel: "kein Eintrag"
                })
            }
            setState('0_userdata.0.Alexa.Einkaufsliste', JSON.stringify(ListeEinkauf), true);
            ListeEinkauf = [];
        },500);
    }
    
    on({id: 'alexa2.0.Lists.SHOPPING_LIST.json', change: 'any'}, Einkaufsliste);
    

    Damit erhältst Du einen DP als JSON. Dieser beinhaltet nur die, die noch nicht erledigt sind.

    Ro75.

    S Offline
    S Offline
    SirPritz
    schrieb am zuletzt editiert von
    #11

    @ro75 sagte in json einfach Filtern (VIS):

    @sirpritz
    So mache ich es:
    createState('0_userdata.0.Alexa.ToDoListe', "[]", {read: true, write: true, desc: "JSON String", type: "string", def: "[]"}); function Einkaufsliste() { setTimeout(function(){ var vEString=''; let ListeEinkauf = []; $('alexa2.0.Lists.SHOPPING_LIST.items.*.value').each(function(id, i) { if(getState(id.replace("value","completed")).val === false) { vEString ='FF'; //dient einfach nur als merkmal, das die Liste nicht leer ist ListeEinkauf.push({ Artikel: getState(id).val }) } }); if(vEString == '') { ListeEinkauf.push({ Artikel: "kein Eintrag" }) } setState('0_userdata.0.Alexa.Einkaufsliste', JSON.stringify(ListeEinkauf), true); ListeEinkauf = []; },500); } on({id: 'alexa2.0.Lists.SHOPPING_LIST.json', change: 'any'}, Einkaufsliste);

    Funktioniert bei mir irgendwie nicht?

    mickymM Ro75R 2 Antworten Letzte Antwort
    0
    • S SirPritz

      @ro75 sagte in json einfach Filtern (VIS):

      @sirpritz
      So mache ich es:
      createState('0_userdata.0.Alexa.ToDoListe', "[]", {read: true, write: true, desc: "JSON String", type: "string", def: "[]"}); function Einkaufsliste() { setTimeout(function(){ var vEString=''; let ListeEinkauf = []; $('alexa2.0.Lists.SHOPPING_LIST.items.*.value').each(function(id, i) { if(getState(id.replace("value","completed")).val === false) { vEString ='FF'; //dient einfach nur als merkmal, das die Liste nicht leer ist ListeEinkauf.push({ Artikel: getState(id).val }) } }); if(vEString == '') { ListeEinkauf.push({ Artikel: "kein Eintrag" }) } setState('0_userdata.0.Alexa.Einkaufsliste', JSON.stringify(ListeEinkauf), true); ListeEinkauf = []; },500); } on({id: 'alexa2.0.Lists.SHOPPING_LIST.json', change: 'any'}, Einkaufsliste);

      Funktioniert bei mir irgendwie nicht?

      mickymM Offline
      mickymM Offline
      mickym
      Most Active
      schrieb am zuletzt editiert von mickym
      #12

      @sirpritz Hänge mal die Daten einfach als in CodeTags rein - dann zeige ich Dir - dass man das mit einem simplen JSONATA Befehl machen kann. Es wäre alles so einfach - wenn ihr in dem FAll einfach Daten und keine Screenshots zur Verfügung stellt.

      https://try.jsonata.org/wIoZmpKDm

      Damit kannst Du Dein Objekt leicht auch mit Javascript filtern:

      var obj = JSON.parse('[{"value":"Feuchttücher","version":2},{"value":"Joghurt","version":1}]')
      console.log(obj);
      console.log("Gefiltert: " + JSON.stringify(await jsonataExpression(obj,'$[version=2]')));
      

      ba417998-5b9e-4fbe-9a18-0502fc8e2554-image.png

      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.

      1 Antwort Letzte Antwort
      0
      • S SirPritz

        @ro75 sagte in json einfach Filtern (VIS):

        @sirpritz
        So mache ich es:
        createState('0_userdata.0.Alexa.ToDoListe', "[]", {read: true, write: true, desc: "JSON String", type: "string", def: "[]"}); function Einkaufsliste() { setTimeout(function(){ var vEString=''; let ListeEinkauf = []; $('alexa2.0.Lists.SHOPPING_LIST.items.*.value').each(function(id, i) { if(getState(id.replace("value","completed")).val === false) { vEString ='FF'; //dient einfach nur als merkmal, das die Liste nicht leer ist ListeEinkauf.push({ Artikel: getState(id).val }) } }); if(vEString == '') { ListeEinkauf.push({ Artikel: "kein Eintrag" }) } setState('0_userdata.0.Alexa.Einkaufsliste', JSON.stringify(ListeEinkauf), true); ListeEinkauf = []; },500); } on({id: 'alexa2.0.Lists.SHOPPING_LIST.json', change: 'any'}, Einkaufsliste);

        Funktioniert bei mir irgendwie nicht?

        Ro75R Offline
        Ro75R Offline
        Ro75
        schrieb am zuletzt editiert von
        #13

        @sirpritz sagte in json einfach Filtern (VIS):

        Funktioniert bei mir irgendwie nicht?

        Wie bzw. was hast du denn gemacht?

        Ro75.

        SERVER = Beelink U59 16GB DDR4 RAM 512GB SSD, FB 7490, FritzDect 200+301+440, ConBee II, Zigbee Aqara Sensoren + NOUS A1Z, NOUS A1T, Philips Hue ** ioBroker, REDIS, influxdb2, Grafana, PiHole, Plex-Mediaserver, paperless-ngx (Docker), MariaDB + phpmyadmin *** VIS-Runtime = Intel NUC 8GB RAM 128GB SSD + 24" Touchscreen

        S 1 Antwort Letzte Antwort
        0
        • Ro75R Ro75

          @sirpritz sagte in json einfach Filtern (VIS):

          Funktioniert bei mir irgendwie nicht?

          Wie bzw. was hast du denn gemacht?

          Ro75.

          S Offline
          S Offline
          SirPritz
          schrieb am zuletzt editiert von Homoran
          #14

          @ro75 Ich habe das Script kopiert und mir den Datenpunkt angelegt, der ist aber leer

          createState('0_userdata.0.Alexa.Einkaufsliste', "[]", {read: true, write: true, desc: "JSON String", type: "string", def: "[]"});
           
          function Einkaufsliste() {
              setTimeout(function(){
                  var vEString='';
                  let ListeEinkauf = [];
                  $('alexa2.0.Lists.SHOPPING_LIST.items*.value').each(function(id, i) {
                      if(getState(id.replace("value","completed")).val === false) {
                          vEString ='FF'; //dient einfach nur als merkmal, das die Liste nicht leer ist
                          ListeEinkauf.push({
                              Artikel: getState(id).val
                          })
                      }
                  });
                  if(vEString == '') {
                      ListeEinkauf.push({
                          Artikel: "kein Eintrag"
                      })
                  }
                  setState('0_userdata.0.Alexa.Einkaufsliste', JSON.stringify(ListeEinkauf), true);
                  ListeEinkauf = [];
              },500);
          }
           
          on({id: 'alexa2.0.Lists.SHOPPING_LIST.json', change: 'any'}, Einkaufsliste);
          

          MOD-EDIT: Code in code-tags gesetzt!

          Ro75R arteckA 2 Antworten Letzte Antwort
          0
          • S SirPritz

            @ro75 Ich habe das Script kopiert und mir den Datenpunkt angelegt, der ist aber leer

            createState('0_userdata.0.Alexa.Einkaufsliste', "[]", {read: true, write: true, desc: "JSON String", type: "string", def: "[]"});
             
            function Einkaufsliste() {
                setTimeout(function(){
                    var vEString='';
                    let ListeEinkauf = [];
                    $('alexa2.0.Lists.SHOPPING_LIST.items*.value').each(function(id, i) {
                        if(getState(id.replace("value","completed")).val === false) {
                            vEString ='FF'; //dient einfach nur als merkmal, das die Liste nicht leer ist
                            ListeEinkauf.push({
                                Artikel: getState(id).val
                            })
                        }
                    });
                    if(vEString == '') {
                        ListeEinkauf.push({
                            Artikel: "kein Eintrag"
                        })
                    }
                    setState('0_userdata.0.Alexa.Einkaufsliste', JSON.stringify(ListeEinkauf), true);
                    ListeEinkauf = [];
                },500);
            }
             
            on({id: 'alexa2.0.Lists.SHOPPING_LIST.json', change: 'any'}, Einkaufsliste);
            

            MOD-EDIT: Code in code-tags gesetzt!

            Ro75R Offline
            Ro75R Offline
            Ro75
            schrieb am zuletzt editiert von Ro75
            #15

            @sirpritz hast du alles in ein neues JS Skript einkopiert und dann das Skript gestartet? Der DP wird automatisch angelegt.

            Ro75.

            Edit: wie lautet denn dein DP für die Einkaufsliste?

            SERVER = Beelink U59 16GB DDR4 RAM 512GB SSD, FB 7490, FritzDect 200+301+440, ConBee II, Zigbee Aqara Sensoren + NOUS A1Z, NOUS A1T, Philips Hue ** ioBroker, REDIS, influxdb2, Grafana, PiHole, Plex-Mediaserver, paperless-ngx (Docker), MariaDB + phpmyadmin *** VIS-Runtime = Intel NUC 8GB RAM 128GB SSD + 24" Touchscreen

            S 1 Antwort Letzte Antwort
            0
            • S SirPritz

              @ro75 Ich habe das Script kopiert und mir den Datenpunkt angelegt, der ist aber leer

              createState('0_userdata.0.Alexa.Einkaufsliste', "[]", {read: true, write: true, desc: "JSON String", type: "string", def: "[]"});
               
              function Einkaufsliste() {
                  setTimeout(function(){
                      var vEString='';
                      let ListeEinkauf = [];
                      $('alexa2.0.Lists.SHOPPING_LIST.items*.value').each(function(id, i) {
                          if(getState(id.replace("value","completed")).val === false) {
                              vEString ='FF'; //dient einfach nur als merkmal, das die Liste nicht leer ist
                              ListeEinkauf.push({
                                  Artikel: getState(id).val
                              })
                          }
                      });
                      if(vEString == '') {
                          ListeEinkauf.push({
                              Artikel: "kein Eintrag"
                          })
                      }
                      setState('0_userdata.0.Alexa.Einkaufsliste', JSON.stringify(ListeEinkauf), true);
                      ListeEinkauf = [];
                  },500);
              }
               
              on({id: 'alexa2.0.Lists.SHOPPING_LIST.json', change: 'any'}, Einkaufsliste);
              

              MOD-EDIT: Code in code-tags gesetzt!

              arteckA Offline
              arteckA Offline
              arteck
              Developer Most Active
              schrieb am zuletzt editiert von
              #16

              @sirpritz code bitte in Code Tag

              b785c19b-2731-4b57-a5b3-cc8ed6ff2a16-grafik.png

              kann man besser lesen

              zigbee hab ich, zwave auch, nuc's genauso und HA auch

              S 1 Antwort Letzte Antwort
              0
              • Ro75R Ro75

                @sirpritz hast du alles in ein neues JS Skript einkopiert und dann das Skript gestartet? Der DP wird automatisch angelegt.

                Ro75.

                Edit: wie lautet denn dein DP für die Einkaufsliste?

                S Offline
                S Offline
                SirPritz
                schrieb am zuletzt editiert von
                #17

                @ro75 alexa2.0.Lists.SHOPPING_LIST.json

                Ro75R 1 Antwort Letzte Antwort
                0
                • arteckA arteck

                  @sirpritz code bitte in Code Tag

                  b785c19b-2731-4b57-a5b3-cc8ed6ff2a16-grafik.png

                  kann man besser lesen

                  S Offline
                  S Offline
                  SirPritz
                  schrieb am zuletzt editiert von Homoran
                  #18

                  @arteck

                  createState('0_userdata.0.Alexa.Einkaufsliste', "[]", {read: true, write: true, desc: "JSON String", type: "string", def: "[]"});
                   
                  function Einkaufsliste() {
                      setTimeout(function(){
                          var vEString='';
                          let ListeEinkauf = [];
                          $('alexa2.0.Lists.SHOPPING_LIST.items*.value').each(function(id, i) {
                              if(getState(id.replace("value","completed")).val === false) {
                                  vEString ='FF'; //dient einfach nur als merkmal, das die Liste nicht leer ist
                                  ListeEinkauf.push({
                                      Artikel: getState(id).val
                                  })
                              }
                          });
                          if(vEString == '') {
                              ListeEinkauf.push({
                                  Artikel: "kein Eintrag"
                              })
                          }
                          setState('0_userdata.0.Alexa.Einkaufsliste', JSON.stringify(ListeEinkauf), true);
                          ListeEinkauf = [];
                      },500);
                  }
                   
                  on({id: 'alexa2.0.Lists.SHOPPING_LIST.json', change: 'any'}, Einkaufsliste);
                  
                  1 Antwort Letzte Antwort
                  0
                  • S SirPritz

                    @ro75 alexa2.0.Lists.SHOPPING_LIST.json

                    Ro75R Offline
                    Ro75R Offline
                    Ro75
                    schrieb am zuletzt editiert von Ro75
                    #19

                    @sirpritz Und der Rest von meinem Beitrag? Starte das Skript und füge was der Einkaufsliste hinzu oder lösche erledige was davon. Das Skript reagiert nur auf Änderungen.

                    SERVER = Beelink U59 16GB DDR4 RAM 512GB SSD, FB 7490, FritzDect 200+301+440, ConBee II, Zigbee Aqara Sensoren + NOUS A1Z, NOUS A1T, Philips Hue ** ioBroker, REDIS, influxdb2, Grafana, PiHole, Plex-Mediaserver, paperless-ngx (Docker), MariaDB + phpmyadmin *** VIS-Runtime = Intel NUC 8GB RAM 128GB SSD + 24" Touchscreen

                    S 1 Antwort Letzte Antwort
                    0
                    • Ro75R Ro75

                      @sirpritz Und der Rest von meinem Beitrag? Starte das Skript und füge was der Einkaufsliste hinzu oder lösche erledige was davon. Das Skript reagiert nur auf Änderungen.

                      S Offline
                      S Offline
                      SirPritz
                      schrieb am zuletzt editiert von SirPritz
                      #20

                      @ro75 OK, versuche es mal weiter...., danke.

                      Danke, so funktioniert es Perfekt, das ist das was ich gesucht habe, echt nochmal vielen Dank.

                      1 Antwort Letzte Antwort
                      0
                      • mickymM Offline
                        mickymM Offline
                        mickym
                        Most Active
                        schrieb am zuletzt editiert von
                        #21

                        Manchmal frag ich mich, warum ich überhaupt poste - wenn es ignoriert wird.

                        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.

                        Ro75R S 2 Antworten Letzte Antwort
                        0
                        • mickymM mickym

                          Manchmal frag ich mich, warum ich überhaupt poste - wenn es ignoriert wird.

                          Ro75R Offline
                          Ro75R Offline
                          Ro75
                          schrieb am zuletzt editiert von
                          #22

                          @mickym wieso, Lösung hat er doch.

                          SERVER = Beelink U59 16GB DDR4 RAM 512GB SSD, FB 7490, FritzDect 200+301+440, ConBee II, Zigbee Aqara Sensoren + NOUS A1Z, NOUS A1T, Philips Hue ** ioBroker, REDIS, influxdb2, Grafana, PiHole, Plex-Mediaserver, paperless-ngx (Docker), MariaDB + phpmyadmin *** VIS-Runtime = Intel NUC 8GB RAM 128GB SSD + 24" Touchscreen

                          1 Antwort Letzte Antwort
                          0
                          • mickymM mickym

                            Manchmal frag ich mich, warum ich überhaupt poste - wenn es ignoriert wird.

                            S Offline
                            S Offline
                            SirPritz
                            schrieb am zuletzt editiert von
                            #23

                            @mickym Sorry, mit deinem Ansatz kam ich nicht weiter.
                            Die andere Lösung hat dann aber gepasst.
                            Hätte nochmal nachfragen können, aber bei mir kommt jetzt alles richtig an, danke nochmal.

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


                            Support us

                            ioBroker
                            Community Adapters
                            Donate

                            324

                            Online

                            32.6k

                            Benutzer

                            82.0k

                            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