Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Datenquelle ermitteln

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    Datenquelle ermitteln

    This topic has been deleted. Only users with topic management privileges can see it.
    • Homoran
      Homoran Global Moderator Administrators @mickym last edited by

      @mickym sagte in Datenquelle ermitteln:

      mit dem Doppelpunkt und Leerzeichen

      😱 hab ich am Handy gar nicht gesehen!

      mickym 1 Reply Last reply Reply Quote 0
      • mickym
        mickym Most Active @Homoran last edited by

        @homoran Na ich habe gesehen (auf dem Screenshot) ist nur im Namen nicht in der ID selbst. 😉

        1 Reply Last reply Reply Quote 0
        • Homoran
          Homoran Global Moderator Administrators @Linedancer last edited by

          @linedancer sagte in Datenquelle ermitteln:

          Unbenannt.png

          Ich hab natürlich die Zuordnung der Räume gepflegt, aber wie gesagt, keine Idee wie ich mit Blockly darauf zugreifen kann.

          Das Ganze soll dazu dienen zu ermitteln in welcher Raum es sinnvoll ist PV Überschuss elektrisch zu verheizen und wo nicht.

          da sind sie ja, die Objekte!!

          @homoran sagte in Datenquelle ermitteln:

          zeig doch mal die Objekte

          1 Reply Last reply Reply Quote 0
          • L
            Linedancer last edited by Linedancer

            Die Dopprlpunkte sind tatsächlich nur im Namen und nicht in der ID. Das kommt direkt von der CCU so.

            mickym 1 Reply Last reply Reply Quote 0
            • mickym
              mickym Most Active @Linedancer last edited by mickym

              @linedancer Wie gesagt am einfachsten ist, Du machst Dir selbst ein Übersetzungsobjekt. Ansonsten schau ich mal - kommst Du ohne JS nicht aus, weil Du via Blockly keinen Zugriff auf die Aufzählungsobjekte hast. Ich überleg mal was. 😉

              1 Reply Last reply Reply Quote 0
              • L
                Linedancer last edited by Linedancer

                Ich würde auch Node Red nehmen 😉 wenn’s mit Blockly nicht machbar ist

                paul53 mickym 2 Replies Last reply Reply Quote 0
                • paul53
                  paul53 @Linedancer last edited by

                  @linedancer sagte: wenn’s mit Blockly nicht machbar ist

                  Ist es mit zwei korrespondierenden Listen und einer Schleife.

                  Blockly_temp.JPG

                  Homoran L 2 Replies Last reply Reply Quote 2
                  • Homoran
                    Homoran Global Moderator Administrators @paul53 last edited by Homoran

                    @paul53 dann muss die manuelle gefüllte Liste idsRoom nur die gleiche Reihenfolge haben wie die Sensoren

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

                      @homoran sagte: dann muss die manuelle gefüllte Liste Rooms nur die gleiche Reihenfolge haben wie die Sensoren

                      Das meinte ich mit "korrespondierend".

                      1 Reply Last reply Reply Quote 0
                      • mickym
                        mickym Most Active @Linedancer last edited by mickym

                        @linedancer sagte in Datenquelle ermitteln:

                        Ich würde auch Node Red nehmen 😉 wenn’s mit Blockly nicht machbar ist

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

                          @paul53 sagte in Datenquelle ermitteln:

                          Ist es mit zwei korrespondierenden Listen und einer Schleife.

                          Ich denke ich hab das Blockly verstanden, auch wenn ich bis jetzt nix mit Schleifen gemacht hab.
                          Das Bau ich morgen nach melde mich. Heut wird das nix mehr.

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

                            Ok hier nun meine NodeRed Lösung.

                            Ich habe mal folgende Testdatenpunkte angelegt, damit das in etwa Deiner Struktur gleich kommt.

                            3d7ed08a-af99-436b-a58c-7527601005d1-image.png

                            Ich habe also die Enums genommen, die im System verankert sind. 😉
                            Du siehst einmal ist der Raum Wohnzimmer, dann Bad.

                            a10c5e01-8819-409f-8429-8f4fb251eb34-image.png

                            [
                               {
                                   "id": "2df53e5d19a0cb01",
                                   "type": "ioBroker list",
                                   "z": "7e6af0015415146d",
                                   "name": "",
                                   "topic": "",
                                   "objType": "",
                                   "regex": "",
                                   "asArray": "false",
                                   "onlyIDs": "false",
                                   "withValues": "false",
                                   "x": 810,
                                   "y": 3180,
                                   "wires": [
                                       [
                                           "f8e6aad5dbd578ac"
                                       ]
                                   ]
                               },
                               {
                                   "id": "87bcd684e308ef6e",
                                   "type": "debug",
                                   "z": "7e6af0015415146d",
                                   "name": "Raum",
                                   "active": true,
                                   "tosidebar": true,
                                   "console": false,
                                   "tostatus": false,
                                   "complete": "payload",
                                   "targetType": "msg",
                                   "statusVal": "",
                                   "statusType": "auto",
                                   "x": 1170,
                                   "y": 3180,
                                   "wires": []
                               },
                               {
                                   "id": "f8e6aad5dbd578ac",
                                   "type": "change",
                                   "z": "7e6af0015415146d",
                                   "name": "",
                                   "rules": [
                                       {
                                           "t": "set",
                                           "p": "payload",
                                           "pt": "msg",
                                           "to": "$each(payload.enums,function($v, $k) {$contains($k,\"rooms\") ? $v})",
                                           "tot": "jsonata"
                                       }
                                   ],
                                   "action": "",
                                   "property": "",
                                   "from": "",
                                   "to": "",
                                   "reg": false,
                                   "x": 990,
                                   "y": 3180,
                                   "wires": [
                                       [
                                           "87bcd684e308ef6e"
                                       ]
                                   ]
                               },
                               {
                                   "id": "ca329680d55789a4",
                                   "type": "ioBroker in",
                                   "z": "7e6af0015415146d",
                                   "name": "",
                                   "topic": "0_userdata.0.Test.Temperaturen.*.Temperatur",
                                   "payloadType": "value",
                                   "onlyack": "",
                                   "func": "all",
                                   "gap": "",
                                   "fireOnStart": "false",
                                   "outFormat": "MQTT",
                                   "x": 210,
                                   "y": 3180,
                                   "wires": [
                                       [
                                           "d81ce08693b81463"
                                       ]
                                   ]
                               },
                               {
                                   "id": "d81ce08693b81463",
                                   "type": "switch",
                                   "z": "7e6af0015415146d",
                                   "name": "",
                                   "property": "max",
                                   "propertyType": "flow",
                                   "rules": [
                                       {
                                           "t": "lt",
                                           "v": "payload",
                                           "vt": "msg"
                                       },
                                       {
                                           "t": "null"
                                       }
                                   ],
                                   "checkall": "true",
                                   "repair": false,
                                   "outputs": 2,
                                   "x": 470,
                                   "y": 3180,
                                   "wires": [
                                       [
                                           "6db8ef90a96693aa"
                                       ],
                                       [
                                           "6db8ef90a96693aa"
                                       ]
                                   ]
                               },
                               {
                                   "id": "6db8ef90a96693aa",
                                   "type": "change",
                                   "z": "7e6af0015415146d",
                                   "name": "",
                                   "rules": [
                                       {
                                           "t": "set",
                                           "p": "max",
                                           "pt": "flow",
                                           "to": "payload",
                                           "tot": "msg"
                                       }
                                   ],
                                   "action": "",
                                   "property": "",
                                   "from": "",
                                   "to": "",
                                   "reg": false,
                                   "x": 640,
                                   "y": 3180,
                                   "wires": [
                                       [
                                           "2df53e5d19a0cb01"
                                       ]
                                   ]
                               },
                               {
                                   "id": "1869413e4e017020",
                                   "type": "inject",
                                   "z": "7e6af0015415146d",
                                   "name": "reset",
                                   "props": [
                                       {
                                           "p": "reset",
                                           "v": "true",
                                           "vt": "bool"
                                       }
                                   ],
                                   "repeat": "",
                                   "crontab": "",
                                   "once": false,
                                   "onceDelay": 0.1,
                                   "topic": "",
                                   "x": 470,
                                   "y": 3240,
                                   "wires": [
                                       [
                                           "e98b2e244eb334ee"
                                       ]
                                   ]
                               },
                               {
                                   "id": "e98b2e244eb334ee",
                                   "type": "change",
                                   "z": "7e6af0015415146d",
                                   "name": "",
                                   "rules": [
                                       {
                                           "t": "delete",
                                           "p": "max",
                                           "pt": "flow"
                                       }
                                   ],
                                   "action": "",
                                   "property": "",
                                   "from": "",
                                   "to": "",
                                   "reg": false,
                                   "x": 650,
                                   "y": 3240,
                                   "wires": [
                                       []
                                   ]
                               }
                            ]
                            

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

                              Ok und hier nun meine Blockly Lösung - mit JS - ermittelt den Raum aus der Objekt ID

                              4d5284df-f802-4b18-b660-a1e9ec5b02f6-image.png

                              <xml xmlns="https://developers.google.com/blockly/xml">
                               <variables>
                                 <variable id="ALTyF=LZs}rPzBcD(1^(">ID</variable>
                                 <variable id="b1|*w2/IBSZtltFBq[mt">Max</variable>
                               </variables>
                               <block type="procedures_defcustomreturn" id="9M;cS2116}Q=Cw,Bj614" x="87" y="-363">
                                 <mutation statements="false">
                                   <arg name="ID" varid="ALTyF=LZs}rPzBcD(1^("></arg>
                                 </mutation>
                                 <field name="NAME">getRoom</field>
                                 <field name="SCRIPT">dmFyIG9iaiA9IHt9Ow0Kb2JqLnNlYXJjaCA9IElEOw0Kb2JqLnJvb21zID0gZ2V0RW51bXMoJ3Jvb21zJyk7DQpyZXR1cm4gYXdhaXQganNvbmF0YUV4cHJlc3Npb24ob2JqLCIkLnJvb21zWyQkLnNlYXJjaCBpbiBtZW1iZXJzXS5uYW1lIik7</field>
                                 <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                               </block>
                               <block type="variables_set" id="hT|PTjDQZc|bKu:?[[zb" x="87" y="-287">
                                 <field name="VAR" id="b1|*w2/IBSZtltFBq[mt">Max</field>
                                 <value name="VALUE">
                                   <block type="math_number" id="F05G|j80GCJgv+,@tW_@">
                                     <field name="NUM">-30</field>
                                   </block>
                                 </value>
                                 <next>
                                   <block type="on_ext" id="4}3oeeat{mVDhPWIv#$@">
                                     <mutation xmlns="http://www.w3.org/1999/xhtml" items="2"></mutation>
                                     <field name="CONDITION">any</field>
                                     <field name="ACK_CONDITION"></field>
                                     <value name="OID0">
                                       <shadow type="field_oid" id="O_Hiq6qP6{;ZCo,39k`U">
                                         <field name="oid">0_userdata.0.Test.Temperaturen.Bad.Temperatur</field>
                                       </shadow>
                                     </value>
                                     <value name="OID1">
                                       <shadow type="field_oid" id="0@$.bMAo[1#1/2mYKs8T">
                                         <field name="oid">0_userdata.0.Test.Temperaturen.Wohnzimmer.Temperatur</field>
                                       </shadow>
                                     </value>
                                     <statement name="STATEMENT">
                                       <block type="controls_if" id="`yyEGE6E{M?~Pe}kF4YB">
                                         <value name="IF0">
                                           <block type="logic_compare" id="El:P_-DP4vlJJY={Fd/(">
                                             <field name="OP">GT</field>
                                             <value name="A">
                                               <block type="on_source" id="FM-hrz1fFe+I2YfRZWY:">
                                                 <field name="ATTR">state.val</field>
                                               </block>
                                             </value>
                                             <value name="B">
                                               <block type="variables_get" id="zb(D$R30?UAw~A{O76r9">
                                                 <field name="VAR" id="b1|*w2/IBSZtltFBq[mt">Max</field>
                                               </block>
                                             </value>
                                           </block>
                                         </value>
                                         <statement name="DO0">
                                           <block type="variables_set" id="ipx(~jBY#t{IEa/1Mr@Z">
                                             <field name="VAR" id="b1|*w2/IBSZtltFBq[mt">Max</field>
                                             <value name="VALUE">
                                               <block type="on_source" id="%G0r$1HCsZ3#[r!yrL4a">
                                                 <field name="ATTR">state.val</field>
                                               </block>
                                             </value>
                                             <next>
                                               <block type="debug" id="Wg8Ay#ioly{/fkOTH:_R">
                                                 <field name="Severity">log</field>
                                                 <value name="TEXT">
                                                   <shadow type="text" id="!VL#h,d@zxcAl#6!0ut+">
                                                     <field name="TEXT">test</field>
                                                   </shadow>
                                                   <block type="procedures_callcustomreturn" id="YmgZHu$By;yP{|d}$XSE">
                                                     <mutation name="getRoom">
                                                       <arg name="ID"></arg>
                                                     </mutation>
                                                     <value name="ARG0">
                                                       <block type="on_source" id="UzY1~8w~z7.Xs#x9v;l1">
                                                         <field name="ATTR">id</field>
                                                       </block>
                                                     </value>
                                                   </block>
                                                 </value>
                                               </block>
                                             </next>
                                           </block>
                                         </statement>
                                       </block>
                                     </statement>
                                   </block>
                                 </next>
                               </block>
                              </xml>
                              

                              Der Reset wird momentan durch Neustart des Skripts gemacht. Aber das sollte ja kein Problem sein, das Maximum entsprechend zu setzen. Wenn ein Datenpunkt 2 Räumen zugeordnet ist, dann kommt ein Array mit beiden Räumen raus. 😉

                              d2dd7028-bf4c-416b-bcde-dc8302dead73-image.png

                              a8b40e48-3cc6-4e97-a80a-65391866afe8-image.png

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

                                In beiden Lösungen habe ich auf Arrays und Listen verzichtet, da es ja nur darum geht, ob es ein neues Maximum gibt und das wird einmal in der Variablen gespeichert. ggf. könnte man das Maximum auch in einem Datenpunkt festhalten. Die Werte, die kein Maximum darstellen sind mE unwichtig.

                                Das zyklische Auslesen aller Werte und speichern in Arrays kann man machen Ich bin davon kein Anhänger.

                                3be41ad4-55e2-41db-90cc-2cfec5981786-image.png

                                <xml xmlns="https://developers.google.com/blockly/xml">
                                 <variables>
                                   <variable id="ALTyF=LZs}rPzBcD(1^(">ID</variable>
                                   <variable id="b1|*w2/IBSZtltFBq[mt">Max</variable>
                                   <variable id="c|3E03D|}2G4$KV$KDcI">idsTemp</variable>
                                 </variables>
                                 <block type="procedures_defcustomreturn" id="9M;cS2116}Q=Cw,Bj614" x="-12" y="-362">
                                   <mutation statements="false">
                                     <arg name="ID" varid="ALTyF=LZs}rPzBcD(1^("></arg>
                                   </mutation>
                                   <field name="NAME">getRoom</field>
                                   <field name="SCRIPT">dmFyIG9iaiA9IHt9Ow0Kb2JqLnNlYXJjaCA9IElEOw0Kb2JqLnJvb21zID0gZ2V0RW51bXMoJ3Jvb21zJyk7DQpyZXR1cm4gYXdhaXQganNvbmF0YUV4cHJlc3Npb24ob2JqLCIkLnJvb21zWyQkLnNlYXJjaCBpbiBtZW1iZXJzXS5uYW1lIik7</field>
                                   <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                                 </block>
                                 <block type="variables_set" id="lsecKayOZ4=Vf/5EgJCm" x="-13" y="-288">
                                   <field name="VAR" id="b1|*w2/IBSZtltFBq[mt">Max</field>
                                   <value name="VALUE">
                                     <block type="math_number" id="e{A/ctXs0!;RsQl_8CBU">
                                       <field name="NUM">-30</field>
                                     </block>
                                   </value>
                                   <next>
                                     <block type="variables_set" id="e|oEG20j1v?9MN[Ekgls">
                                       <field name="VAR" id="c|3E03D|}2G4$KV$KDcI">idsTemp</field>
                                       <value name="VALUE">
                                         <block type="lists_create_with" id="s/k[)5H$IS*+,-X`C.vj">
                                           <mutation items="2"></mutation>
                                           <value name="ADD0">
                                             <block type="field_oid" id="59TZ(Xip0eevyJ+Nz#W[">
                                               <field name="oid">0_userdata.0.Test.Temperaturen.Bad.Temperatur</field>
                                             </block>
                                           </value>
                                           <value name="ADD1">
                                             <block type="field_oid" id="QE7RX_:Zn@LO7PuoNdD*">
                                               <field name="oid">0_userdata.0.Test.Temperaturen.Wohnzimmer.Temperatur</field>
                                             </block>
                                           </value>
                                         </block>
                                       </value>
                                       <next>
                                         <block type="on_ext" id="a;ViTG!bb-pX.jTorvJ8">
                                           <mutation xmlns="http://www.w3.org/1999/xhtml" items="1"></mutation>
                                           <field name="CONDITION">ne</field>
                                           <field name="ACK_CONDITION"></field>
                                           <value name="OID0">
                                             <shadow type="field_oid" id="i%1xDs6.nZ9wnp2aj.MM">
                                               <field name="oid">default</field>
                                             </shadow>
                                             <block type="variables_get" id="E@Gr[#Bwaf=tinJNsv+T">
                                               <field name="VAR" id="c|3E03D|}2G4$KV$KDcI">idsTemp</field>
                                             </block>
                                           </value>
                                           <statement name="STATEMENT">
                                             <block type="controls_forEach" id="8_xK-^laWl]^P}j::7mO">
                                               <field name="VAR" id="ALTyF=LZs}rPzBcD(1^(">ID</field>
                                               <value name="LIST">
                                                 <block type="variables_get" id="c/y];d@:x;IgX3T?fOR3">
                                                   <field name="VAR" id="c|3E03D|}2G4$KV$KDcI">idsTemp</field>
                                                 </block>
                                               </value>
                                               <statement name="DO">
                                                 <block type="controls_if" id="`yyEGE6E{M?~Pe}kF4YB">
                                                   <value name="IF0">
                                                     <block type="logic_compare" id="El:P_-DP4vlJJY={Fd/(">
                                                       <field name="OP">GT</field>
                                                       <value name="A">
                                                         <block type="get_value_var" id="@@uymSTw|kZqu.WZ:fs.">
                                                           <field name="ATTR">val</field>
                                                           <value name="OID">
                                                             <shadow type="text" id="`Gc7SE*~nsYba%DD$D`D">
                                                               <field name="TEXT"></field>
                                                             </shadow>
                                                             <block type="variables_get" id="-!Y0v9V:jSN{KYT#),!m">
                                                               <field name="VAR" id="ALTyF=LZs}rPzBcD(1^(">ID</field>
                                                             </block>
                                                           </value>
                                                         </block>
                                                       </value>
                                                       <value name="B">
                                                         <block type="variables_get" id="zb(D$R30?UAw~A{O76r9">
                                                           <field name="VAR" id="b1|*w2/IBSZtltFBq[mt">Max</field>
                                                         </block>
                                                       </value>
                                                     </block>
                                                   </value>
                                                   <statement name="DO0">
                                                     <block type="variables_set" id="ipx(~jBY#t{IEa/1Mr@Z">
                                                       <field name="VAR" id="b1|*w2/IBSZtltFBq[mt">Max</field>
                                                       <value name="VALUE">
                                                         <block type="get_value_var" id="Va7]-8]?5(d/GAUyT{!,">
                                                           <field name="ATTR">val</field>
                                                           <value name="OID">
                                                             <shadow type="text">
                                                               <field name="TEXT"></field>
                                                             </shadow>
                                                             <block type="variables_get" id="j!GI7IU|Ri0M`gV`*tpg">
                                                               <field name="VAR" id="ALTyF=LZs}rPzBcD(1^(">ID</field>
                                                             </block>
                                                           </value>
                                                         </block>
                                                       </value>
                                                       <next>
                                                         <block type="debug" id="M%1)Q#tj4Zn(,C`Na^Y_">
                                                           <field name="Severity">log</field>
                                                           <value name="TEXT">
                                                             <shadow type="text" id=":@[;Kk#l)s]su?JioeuF">
                                                               <field name="TEXT">test</field>
                                                             </shadow>
                                                             <block type="variables_get" id="/vI;M`yL[0/o4jJa1153">
                                                               <field name="VAR" id="b1|*w2/IBSZtltFBq[mt">Max</field>
                                                             </block>
                                                           </value>
                                                           <next>
                                                             <block type="debug" id="Wg8Ay#ioly{/fkOTH:_R">
                                                               <field name="Severity">log</field>
                                                               <value name="TEXT">
                                                                 <shadow type="text" id="!VL#h,d@zxcAl#6!0ut+">
                                                                   <field name="TEXT">test</field>
                                                                 </shadow>
                                                                 <block type="procedures_callcustomreturn" id="YmgZHu$By;yP{|d}$XSE">
                                                                   <mutation name="getRoom">
                                                                     <arg name="ID"></arg>
                                                                   </mutation>
                                                                   <value name="ARG0">
                                                                     <block type="variables_get" id="U)I)Dcvbv7mJ%eMupUi=">
                                                                       <field name="VAR" id="ALTyF=LZs}rPzBcD(1^(">ID</field>
                                                                     </block>
                                                                   </value>
                                                                 </block>
                                                               </value>
                                                             </block>
                                                           </next>
                                                         </block>
                                                       </next>
                                                     </block>
                                                   </statement>
                                                 </block>
                                               </statement>
                                             </block>
                                           </statement>
                                         </block>
                                       </next>
                                     </block>
                                   </next>
                                 </block>
                                </xml>
                                

                                Wie gesagt ich präferiere die Lösung ohne Listen und damit das Ermitteln des Maximums mit den jeweils aktuell eintrudelnden Werten.

                                L 2 Replies Last reply Reply Quote 0
                                • L
                                  Linedancer @mickym last edited by

                                  @mickym

                                  Auch dir vielen Dank für deine Lösungsvorschläge. Schau ich mir an.

                                  1 Reply Last reply Reply Quote 0
                                  • L
                                    Linedancer @mickym last edited by

                                    So, die Lösung von @paul53 hab ich umgesetzt. Funktioniert so wie ich es mir vorgestellt habe. Danke dafür.

                                    Die Node Red Lösung von @mickym hab ich mir angeschaut, aber da ich (leider) immernoch kein wirkliche Erfahrung mit JavaScript habe, ist mir die reine Blockly Lösung näher. Trotzdem auch dir danke für deine Hilfe.

                                    mickym 1 Reply Last reply Reply Quote 0
                                    • mickym
                                      mickym Most Active @Linedancer last edited by

                                      @linedancer Na meine Blockly-Lösungen greifen halt auf den Raum zu, den Du direkt im Admin eingegeben hast und nicht über eigene Zuordnungen. Und ich dachte das war Dein Hauptziel. Deswegen hab ich halt das Blockly entsprechend mit einer JS Funktion erweitert.

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

                                      Support us

                                      ioBroker
                                      Community Adapters
                                      Donate

                                      879
                                      Online

                                      32.0k
                                      Users

                                      80.5k
                                      Topics

                                      1.3m
                                      Posts

                                      4
                                      26
                                      1098
                                      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