Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. MQTT String generell aufteilen?

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    MQTT String generell aufteilen?

    This topic has been deleted. Only users with topic management privileges can see it.
    • B
      butsch last edited by butsch

      Soweit scheint jetzt alles zu funktionieren, die States sind da und werden auch aktualisiert, aber:

      10:06:33.041	warn	javascript.0 (226402) at script.js.common.MQTT2OBJEKT.Parser:13:13
      10:06:33.041	warn	javascript.0 (226402) at Object.<anonymous> (script.js.common.MQTT2OBJEKT.Parser:12:26)
      
      226402) getState "javascript.0.zigbee2mqtt.OnOff" not found (3)
      

      Was denn da los? ;-(

      F 1 Reply Last reply Reply Quote 0
      • F
        frostnatt @butsch last edited by

        @butsch
        Die Warnings bekomme ich auch seit einiger Zeit. Das Script funktioniert aber weiterhin ohne Probleme bei mir. Muss ich mal bei Gelegenheit debuggen, es fehlt leider im Moment die Zeit...

        1 Reply Last reply Reply Quote 0
        • F
          frostnatt last edited by

          @butsch
          Habe das Problem gefixt, das Script wirft keine Warnings mehr bei mir.

          const JSPath = "javascript.0"                              // JS- Pfad
          const parsedStatesPath   = JSPath + ".zigbee2mqtt"         // Pfad fuer geparste States
          const zigbee2mqttJsonPath = "mqtt.0.zigbee2mqtt"           //Pfad fuer zigbee2mqtt Json Objekte
          let IDs = [];
          
          
          $("[id=" + zigbee2mqttJsonPath + ".*]").each(function (id) {
              IDs.push(id)
          })
          on({id: IDs, change: "ne"}, function (obj) {
              let JsonObj = JSON.parse(obj.state.val)
              Object.keys(JsonObj).forEach(function(key){
                  let currState = obj.id.replace(zigbee2mqttJsonPath, parsedStatesPath) + "." + key
                  if (getState(currState).notExist){
                      createState(currState, JsonObj[key], {read: true, write: true, type: typeof(JsonObj[key]), name: '' , desc: ''},function(){
                          setState(currState, JsonObj[key]);
                  })
                  }else {
                      setState(currState, JsonObj[key])
                  };
              })
          })
          
          metaxa 1 Reply Last reply Reply Quote 0
          • B
            butsch last edited by

            @frostnatt sagte in MQTT String generell aufteilen?:

                                                                                                                                        const JSPath = "javascript.0"                              // JS- Pfad                                                                                                                                                                            const parsedStatesPath   = JSPath + ".zigbee2mqtt"         // Pfad fuer geparste States                                                                                                                                                                            const zigbee2mqttJsonPath = "mqtt.0.zigbee2mqtt"           //Pfad fuer zigbee2mqtt Json Objekte                                                                                                                                                                            let IDs = [];                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      $("[id=" + zigbee2mqttJsonPath + ".*]").each(function (id) {                                                                                                                                                                                IDs.push(id)                                                                                                                                                                            })                                                                                                                                                                            on({id: IDs, change: "ne"}, function (obj) {                                                                                                                                                                                let JsonObj = JSON.parse(obj.state.val)                                                                                                                                                                                Object.keys(JsonObj).forEach(function(key){                                                                                                                                                                                    let currState = obj.id.replace(zigbee2mqttJsonPath, parsedStatesPath) + "." + key                                                                                                                                                                                    if (getState(currState).notExist){                                                                                                                                                                                        createState(currState, JsonObj[key], {read: true, write: true, type: typeof(JsonObj[key]), name: '' , desc: ''},function(){                                                                                                                                                                                            setState(currState, JsonObj[key]);                                                                                                                                                                                    })                                                                                                                                                                                    }else {                                                                                                                                                                                        setState(currState, JsonObj[key])                                                                                                                                                                                    };                                                                                                                                                                                })                                                                                                                                                                            })                                            
            

            Vielen Dank, jetzt passt es!

            1 Reply Last reply Reply Quote 0
            • metaxa
              metaxa @frostnatt last edited by metaxa

              @frostnatt sagte in MQTT String generell aufteilen?:

              @butsch
              Habe das Problem gefixt, das Script wirft keine Warnings mehr bei mir.

              Jetzt habe ich primitiv geglaubt, ich kann mir das Script stehlen, ein wenig anpassen und es läuft..... war ein Irrglaube. Kannst du mir vielleicht bitte helfen?

              schedule("* * * * *", function (){       //alle Minuten
              
              const JSPath = "a_andreas.0.eigene_dp"					// JS- Pfad
              const parsedStatesPath   = JSPath + ".Heizung"			// Pfad fuer geparste States
              const JsonPath = "mqtt.0.ems-esp.sm_data"				// Pfad fuer Json Objekte
              
              let IDs = [];
              
              $("[id=" + JsonPath + ".*]").each(function (id) {
                  IDs.push(id)
              })
              
              on({id: IDs, change: "ne"}, function (obj) {
                  let JsonObj = JSON.parse(obj.state.val)
                  Object.keys(JsonObj).forEach(function(key){
                      let currState = obj.id.replace(JsonPath, parsedStatesPath) + "." + key
                     if (getState(currState).notExist){
                          createState(currState, JsonObj[key], {read: true, write: true, type: typeof(JsonObj[key]), name: '' , desc: ''},function(){
                              setState(currState, JsonObj[key]);
                      })
                      }else {
                          setState(currState, JsonObj[key])
                      };
                  })
              })
              })
              

              fd4394d7-4b1e-448c-955b-8616c922e63c-grafik.png
              57556ad1-405f-438e-89b7-12d95f228838-grafik.png

              {"collectortemp":16,"bottomtemp":57.8,"pump":"off","pumpWorkMin":30500,"energylasthour":0}
              

              Leider tut sich nix ........ bitte um Unterstützung!

              Finde deine Lösung mit dynamischen DP echt genial!!!!
              LG, mxa

              paul53 1 Reply Last reply Reply Quote 0
              • paul53
                paul53 @metaxa last edited by paul53

                @metaxa sagte:

                Leider tut sich nix

                Mit createState() kann man keine Datenpunkte unter "a_andreas.0.eigene_dp" erstellen.
                Außerdem: Was soll das schedule() drumherum ? Damit wird jede Minute ein neuer Trigger erzeugt.

                metaxa 1 Reply Last reply Reply Quote 1
                • metaxa
                  metaxa @paul53 last edited by metaxa

                  @paul53 sagte in MQTT String generell aufteilen?:

                  @metaxa sagte:

                  Leider tut sich nix

                  Mit createState() kann man keine Datenpunkte unter "a_andreas.0.eigene_dp" erstellen.

                  Hi Paul,
                  ich habs geändert ... aber es tut sich auch nix.

                  // schedule("* * * * *", function (){       //alle Minuten
                  
                  const JSPath = "javascript.0"					// JS- Pfad
                  const parsedStatesPath   = JSPath + ".Heizung"			// Pfad fuer geparste States
                  const JsonPath = "mqtt.0.ems-esp.sm_data"				// Pfad fuer Json Objekte
                  
                  

                  Hättest bitte noch eine Idee?

                  Ups ...... hatte ich nicht gesehen: Ich will mit dem Shedule, dass das Script alle Minuten zum Testen ausgeführt wird.

                  paul53 1 Reply Last reply Reply Quote 0
                  • paul53
                    paul53 @metaxa last edited by paul53

                    @metaxa sagte:

                    Hättest bitte noch eine Idee?

                    Du willst einen bestimmten Datenpunkt parsen. Dazu braucht man kein Array of IDs.

                    const idJson = 'mqtt.0.ems-esp.sm_data';
                    const path = 'Heizung.';
                    const js = 'javascript.' + instance + '.';
                    
                    on(idJson, function(dp) { // triggert bei Wertänderung
                       let obj = JSON.parse(dp.state.val);
                       for(let prop in obj) {
                          if(existsState(js + path + prop)) setState(path + prop, obj[prop], true);
                          else createState(path + prop, obj[prop], {type: typeof obj[prop]});
                       }
                    });
                    

                    Bei den Datenpunkten mit Zahlenwerten solltest Du noch manuell die "unit" hinzufügen, denn das geht nicht automatisch.

                    metaxa 1 Reply Last reply Reply Quote 1
                    • metaxa
                      metaxa @paul53 last edited by

                      @paul53 Ich werde es nie lernen und vestehen, danke Paul!
                      Ich versuche es zu kapieren, aber ich komm nicht weit genug. Paar Fragen noch bitte

                      1. wer oder was triggert das Script?
                      2. habe ich Chance meine eigene Struktur zu verwenden ("a_andreas.0.eigene_dp")

                      Ups, sehe gerade noch eine Änderung von dir, baue ich gleich ein - wird sicher Sinn machen, wenn ich auch nicht verstehe welchen 🙂

                      Danke Paul für deine Zeit!

                      paul53 1 Reply Last reply Reply Quote 0
                      • paul53
                        paul53 @metaxa last edited by

                        @metaxa sagte:

                        wer oder was triggert das Script?

                        Getriggert wird bei einer Wertänderung des Datenpunktes 'mqtt.0.ems-esp.sm_data'.

                        @metaxa sagte in MQTT String generell aufteilen?:

                        habe ich Chance meine eigene Struktur zu verwenden ("a_andreas.0.eigene_dp")

                        Ja, aber nicht mit createState() , sondern mit setObject() und setState() im Callback.

                        metaxa 1 Reply Last reply Reply Quote 1
                        • metaxa
                          metaxa @paul53 last edited by metaxa

                          @paul53 🙂 //

                          Da hatte ich doch schon mal was gebastelt, jetzt ist es mir auch klar warum 🙂

                          createState("javascript.0.scriptDatenPunkte.Sprit_AT.Tankstelle_"+index+".Index", 0,{type: 'number', name: 'ID', read: true, write: true});
                                  setState("javascript.0.scriptDatenPunkte.Sprit_AT.Tankstelle_"+index+".Index", gasStation[index].id);
                          

                          Muss mich nochmals reinfuchsen. Ahhh, is doch was anderes ....... ich fuchse .....

                          Zum 27sten mal, danke dir Paul!
                          mxa

                          paul53 1 Reply Last reply Reply Quote 0
                          • paul53
                            paul53 @metaxa last edited by

                            @metaxa sagte:

                            Muss mich nochmals reinfuchsen.

                            Anregung

                            metaxa 1 Reply Last reply Reply Quote 1
                            • metaxa
                              metaxa @paul53 last edited by

                              @paul53 sagte in MQTT String generell aufteilen?:

                              Anregung

                              Üner diesen Thread stolperte ich schon mal, danke für den Link. Um das zu behirnen brauche ich wohl nochmals einen 1 monatigen "Lockdown". Das ist schon ein hartes Stück Brot.

                              LG, mxa

                              1 Reply Last reply Reply Quote 0
                              • R
                                Rushmed Most Active last edited by

                                Hallo, ich habe mir das Script von oben geschnappt und angepasst.

                                Script:

                                const JSPath = "0_userdata.0"                              // JS- Pfad
                                const parsedStatesPath   = JSPath + ".cam_kueche"         // Pfad fuer geparste States
                                const zigbee2mqttJsonPath = "mqtt.0.cam_kueche"           //Pfad fuer zigbee2mqtt Json Objekte
                                let IDs = [];
                                
                                
                                $("[id=" + zigbee2mqttJsonPath + ".*]").each(function (id) {
                                    IDs.push(id)
                                })
                                on({id: IDs, change: "ne"}, function (obj) {
                                    let JsonObj = JSON.parse(obj.state.val)
                                    Object.keys(JsonObj).forEach(function(key){
                                        let currState = obj.id.replace(zigbee2mqttJsonPath, parsedStatesPath) + "." + key
                                        if (getState(currState).notExist){
                                            createState(currState, JsonObj[key], {read: true, write: true, type: typeof(JsonObj[key]), name: '' , desc: ''},function(){
                                                setState(currState, JsonObj[key]);
                                        })
                                        }else {
                                            setState(currState, JsonObj[key])
                                        };
                                    })
                                })
                                

                                Im Datenpunkt steht bspw. dieser Wert:

                                {"start":"2020-11-07T16:06:12+0100","end":"2020-11-07T16:07:12+0100","files":[ "2020Y11M07D16H/07M00S60.mp4", "2020Y11M07D16H/06M10S50.mp4", "2020Y11M07D16H/05M00S60.mp4" ]}
                                

                                Das Script legt die Datenpunkte an und befüllt sie auch.
                                2b416f36-f3fe-4dfc-924b-9a9659759285-grafik.png

                                Im Log passier allerdings folgendes:

                                javascript.0	2020-11-07 16:06:15.130	error	(17569) at processImmediate (internal/timers.js:461:21)
                                javascript.0	2020-11-07 16:06:15.130	error	(17569) at Immediate._onImmediate (/opt/iobroker/node_modules/iobroker.js-controller/lib/adapter.js:5384:37)
                                javascript.0	2020-11-07 16:06:15.130	error	(17569) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:463:25)
                                javascript.0	2020-11-07 16:06:15.129	error	(17569) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1065:38)
                                javascript.0	2020-11-07 16:06:15.129	error	(17569) at Object.<anonymous> (script.js.Parsing.cam_kueche:11:24)
                                javascript.0	2020-11-07 16:06:15.129	error	(17569) at JSON.parse (<anonymous>:null:null)
                                javascript.0	2020-11-07 16:06:15.128	error	(17569) Error in callback: SyntaxError: Unexpected token � in JSON at position 0
                                

                                Kann mir jemand helfen die Fehlermeldungen zu verstehen?

                                R 1 Reply Last reply Reply Quote 0
                                • R
                                  Rushmed Most Active @Rushmed last edited by

                                  @Rushmed Hat niemand ne Idee?

                                  1 Reply Last reply Reply Quote 0
                                  • First post
                                    Last post

                                  Support us

                                  ioBroker
                                  Community Adapters
                                  Donate

                                  777
                                  Online

                                  31.8k
                                  Users

                                  80.0k
                                  Topics

                                  1.3m
                                  Posts

                                  javascript
                                  7
                                  28
                                  2608
                                  Loading More Posts
                                  • Oldest to Newest
                                  • Newest to Oldest
                                  • Most Votes
                                  Reply
                                  • Reply as topic
                                  Log in to reply
                                  Community
                                  Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                  The ioBroker Community 2014-2023
                                  logo