NEWS
Hilfe: Letzte zahl in Blockly vergleichen [6,-48,-41]
-
puhh wie soll das funktionieren ?
In dem Objekt steht ist der Wert exakt: " [6,-48,-41] " also mit den Klammern.
-
Du kannst mit dem Baustein "JSON nach Objekt" unter Konvertierung eine Liste daraus erstellen. Aus dieser kannst du dann das letzte Element nehmen und erhältst direkt eine Zahl (keinen Text).
-
hui klingt Kompliziert hab es aber mal nachgebaut leider scheint noch was nicht zu stimmen. Bekomme im Log beim Blockly
21:22:53.373 error javascript.0 at Object.<anonymous> (script.js.Tests.Dachfenster-offen-check:4:114)
hier das Blockly
<xml xmlns="http://www.w3.org/1999/xhtml"> <block type="on_ext" id="0O%[N?*o;L[-Z*e$cZ|l" x="138" y="-138"> <mutation items="1"></mutation> <field name="CONDITION">ne</field> <field name="ACK_CONDITION"></field> <value name="OID0"> <shadow type="field_oid" id="D!AT5%oNC0)%5Fi*DN5m"> <field name="oid">deconz.0.Sensors.11.orientation</field> </shadow> </value> <statement name="STATEMENT"> <block type="controls_if" id="agj5-y|}16ucKgXQ3uo2"> <mutation else="1"></mutation> <value name="IF0"> <block type="logic_compare" id="=P{+E-ep%]Qj0A?eeaKI"> <field name="OP">EQ</field> <value name="A"> <block type="math_number" id="av4wXWOb[R2;-Tndi^`-"> <field name="NUM">-71</field> </block> </value> <value name="B"> <block type="lists_getIndex" id="ki,3S|{@];cQtZ-gbVX?"> <mutation statement="false" at="false"></mutation> <field name="MODE">GET</field> <field name="WHERE">LAST</field> <value name="VALUE"> <block type="convert_json2object" id="yQ@b,SIl3S#5n}JX87}s"> <value name="VALUE"> <block type="on_source" id="@jF99~q{-,Z^{PB_{t/~"> <field name="ATTR">state.val</field> </block> </value> </block> </value> </block> </value> </block> </value> <statement name="DO0"> <block type="telegram" id="AIfc3XzI4/ne#!-Y|xGF"> <field name="INSTANCE"></field> <field name="LOG"></field> <field name="SILENT">FALSE</field> <field name="PARSEMODE">default</field> <value name="MESSAGE"> <shadow type="text" id="0yZgReeq@hej?P6pG?8m"> <field name="TEXT">OFFEN</field> </shadow> </value> </block> </statement> <statement name="ELSE"> <block type="telegram" id="$y;bd;9%]YI!fiFbe4cX"> <field name="INSTANCE"></field> <field name="LOG"></field> <field name="SILENT">FALSE</field> <field name="PARSEMODE">default</field> <value name="MESSAGE"> <shadow type="text" id="cO+0BbD;*4rYLa^uAje1"> <field name="TEXT">ZU</field> </shadow> </value> </block> </statement> </block> </statement> </block> </xml>
Nicht wundern wegen 71 ist ein Testgerät
-
@ChrisXY Kannst du einmal als erstes Element in den Trigger einen Debug Baustein mit dem Wert setzen? Dann sollte im Log der Wert ausgegeben werden, von dem du bitte einen Screenshot erstellst.
-
21:36:46.986 info javascript.0 script.js.Tests.Dachfenster-offen-check: 0,19,71 21:36:46.987 error javascript.0 at Object.<anonymous> (script.js.Tests.Dachfenster-offen-check:8:114)
-
Dort scheinen keine eckigen Klammern im Datenpunkt zu stehen. Ist das bei dem anderen Gerät anders, wenn du den Log Baustein einfügst?
-
hab nun noch mehr debug gemacht aber dann scheint das - weg zu sein:
21:39:54.897 info javascript.0 script.js.Tests.Dachfenster-offen-check: 1,19,71 21:39:54.897 error javascript.0 at Object.<anonymous> (script.js.Tests.Dachfenster-offen-check:8:114) 21:40:03.279 info javascript.0 script.js.Tests.Dachfenster-offen-check: 1,19,71 21:40:03.280 error javascript.0 at Object.<anonymous> (script.js.Tests.Dachfenster-offen-check:8:114)
-
@Xyolyp said in Hilfe: Letzte zahl in Blockly vergleichen [6,-48,-41]:
Dort scheinen keine eckigen Klammern im Datenpunkt zu stehen. Ist das bei dem anderen Gerät anders, wenn du den Log Baustein einfügst?
Stimmt .. hab nochmal geschaut der Wert steht so im Objekt: 1,19,71
Lag wohl am SQL .. sorry -
@Xyolyp Wenn es so im Log dargestellt wir, ist es kein JSON, sondern ein Array. JSON nach Objekt muss also entfallen.
-
@ChrisXY EDIT: Paul hat recht (ich hatte ehrlich gesagt noch keine Liste in meinen Logs gesehen und war davon ausgegangen, dass es ein Text ist. Dies scheint nicht der Fall zu sein. Nachdem das letzte Element aus der Liste geholt wurde muss möglicherweise noch zu einer Zahl konvertiert werden
-
@ChrisXY Was liefert das im Log ?
-
@Xyolyp said in Hilfe: Letzte zahl in Blockly vergleichen [6,-48,-41]:
@ChrisXY EDIT: Paul hat recht (ich hatte ehrlich gesagt noch keine Liste in meinen Logs gesehen und war davon ausgegangen, dass es ein Text ist. Dies scheint nicht der Fall zu sein. Nachdem das letzte Element aus der Liste geholt wurde muss möglicherweise noch zu einer Zahl konvertiert werden
21:50:32.930 info javascript.0 script.js.Tests.Dachfenster-offen-check: 0,19,71
21:50:32.930 error javascript.0 at Object.<anonymous> (script.js.Tests.Dachfenster-offen-check:5:59)
@paul53 said in Hilfe: Letzte zahl in Blockly vergleichen [6,-48,-41]:
@ChrisXY Was liefert das im Log ?
Das hier 21:39:54.897 info javascript.0 script.js.Tests.Dachfenster-offen-check: 1,19,71
-
@ChrisXY sagte:
Das hier 21:39:54.897 info javascript.0 script.js.Tests.Dachfenster-offen-check: 1,19,71
Das ist der Wert, nicht der Typ von Wert !
Die Konvertierung nach Zahl kann entfallen.
-
@Xyolyp said in Hilfe: Letzte zahl in Blockly vergleichen [6,-48,-41]:
@ChrisXY EDIT: Paul hat recht (ich hatte ehrlich gesagt noch keine Liste in meinen Logs gesehen und war davon ausgegangen, dass es ein Text ist. Dies scheint nicht der Fall zu sein. Nachdem das letzte Element aus der Liste geholt wurde muss möglicherweise noch zu einer Zahl konvertiert werden
Nach der anpassung hab ich folgendes im Log
- Debug und nach der liste:
21:57:40.368 info javascript.0 script.js.Tests.Dachfenster-offen-check: 1,18,72
21:57:40.391 info javascript.0 script.js.Tests.Dachfenster-offen-check: 0,1,89
21:57:43.976 info javascript.0 script.js.Tests.Dachfenster-offen-check: 0,1,89
21:57:45.035 info javascript.0 script.js.Tests.Dachfenster-offen-check: -1,19,71
Bekomme Push ZU geschickt .. aber offen nicht obwohl 71 da steht
EDIT: Hab das -71 in 71 getauscht und schon Klappt es
DANKE
- Debug und nach der liste:
-
klappt
Edit: Kann ich statt der 71 auch ein Bereich Definieren quasi 65-75 ??
Und aktuell bekomme ich 4-5 Telegram Nachrichten bei Bewegung. Timeout um das falls mit 3 sekunden hat auch nichts gebracht. Wie Bremse ich das etwas ? -
-
@Xyolyp sagte:
noch keine Liste in meinen Logs gesehen
Wenn Du den aktuellen Javascript-Adapter von Github installierst, werden Objekte / Arrays erkennbar im Log dargestellt.
-
@ChrisXY sagte:
Timeout um das falls mit 3 sekunden hat auch nichts gebracht. Wie Bremse ich das etwas ?
Vor dem Timeout ein stop timeout.
-
oh okay da hätte ich auch noch drauf kommen können. Aber vielen Dank für die ganze Hilfe. Es Klappt bisher sehr gut. Tiggere es jetzt nur bei bestimmten sachen
Da reicht ja dann ein Zustand.
-
unglaublich aber ich bekomm das mit dem zwischen 38 und 43 nicht hin ..
Ich muss da sja mit einem Wert vergleichen??
Hast du mal einen screen vielleicht bekomme ich das dann hin