NEWS
Parser Wert auslesen aber wie?
-
@mickym sagte in Parser Wert auslesen aber wie?:
<xml xmlns="https://developers.google.com/blockly/xml"> <block type="procedures_defcustomreturn" id=".0+pfi#8i#U#jm$iU4:(" x="113" y="-112"> <mutation statements="false"></mutation> <field name="NAME">EMETER_OBIS_V2</field> <field name="SCRIPT">Y29uc3QgYXhpb3MgPSByZXF1aXJlKCdheGlvcycpOw0KIA0KY29uc3QgdXJsID0gJ2h0dHA6Ly8xOTIuMTY4LjEwLjIxMi9kYXRhJzsNCiANCnJldHVybiBheGlvcy5nZXQodXJsLCB7IGluc2VjdXJlSFRUUFBhcnNlcjogdHJ1ZSB9KS50aGVuKChyZXNwb25zZSkgPT4gcmVzcG9uc2UuZGF0YSk7DQo=</field> <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment> </block> <block type="debug" id="(#D=4jImQYEWBq9nk/o." x="113" y="-62"> <field name="Severity">log</field> <value name="TEXT"> <shadow type="text" id="Ipk)om!*g3w3lb+7ERhe"> <field name="TEXT">test</field> </shadow> <block type="procedures_callcustomreturn" id="}DioNbC)Da-GiVrMZiBd"> <mutation name="EMETER_OBIS_V2"></mutation> </block> </value> </block> </xml>
Das klappt!!!
-
@g-hawk Kannst Du bitte wieder mal einen Screenshot der Debug Ausgabe machen - ich muss sehen ob man das Objekt direkt nutzen kann.
oder schau ob das auch noch klappt:
-
Das Ergebnis stimmt
-
@g-hawk Na dann kannst Du doch nun direkt mit aktualisiere Datenpunkt die Werte in die Datenpunkte schreiben.
-
@mickym
Warte Ich teste -
Wie geil ist das denn!!!!
Vielen vielen Dank für deine Zeit und deine Mühe.
Die Lösung könnte ich nochmal in dem Elmo Beitrag bekanntgeben.
Super endlich funktioniert es.
-
@g-hawk Na ja - erst mussten wir ja mal dem Problem auf die Spur kommen.
Wenn Du nicht zufälligerweise
Und ich muss im Parser ankreuzen " Verwenden sie einen unsicheren HTTP Parser
das in diesem Posting erwähnt hättest, hätte ich ja nie nach einer Lösung gesucht.
Du siehst jede Information ist wertvoll.
Wenn Du das Blockly noch flexibler machen willst - dann rufst du die Funktion halt mit der URL auf - dann kann man das universeller nutzen. Im Moment ist die URL ja fest codiert in der Funktion.
-
@mickym
Ich habe es jetzt so gelöst: -
@g-hawk Ja für Dich passt das - aber vielleicht haben ja andere eine andere URL um das nicht in der Funktion anpassen zu müssen - könnte man die URL auch im Blockly mitgeben:
und wenn das hinhaut - dann kann man in der Funktion die auskommentierte URL löschen.
Also die Zeile 3:
-
@mickym
Hallo.
Ich habe heute ein Update des Java Adapters gemacht.
Leider funktioniert das Script jetzt nicht mehr.
In den Update Informationen stand auch ,dass man irgendwas ändern muss, wenn man Jsonata Blöcke verwendet.Kann da jemand helfen?
-
@g-hawk Ich hab irgendwo mal gelesen, dass man das Script nochmal neu speicher muss.
-
@g-hawk sagte in Parser Wert auslesen aber wie?:
Ich habe heute ein Update des Java Adapters gemacht.
zeig mal auf welche Version bitte
-
7.0.3
2023-06-21 21:38:00.392 warn at processTicksAndRejections (node:internal/process/task_queues:95:5) javascript.0 2023-06-21 21:38:00.392 warn at processTicksAndRejections (node:internal/process/task_queues:95:5) javascript.0 2023-06-21 21:38:00.392 warn at processTicksAndRejections (node:internal/process/task_queues:95:5) javascript.0 2023-06-21 21:38:00.392 warn at Object.<anonymous> (script.js_.Strom.Gesamtstrom.Elmo_auslesen:19:3) javascript.0 2023-06-21 21:38:00.392 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1730:20) javascript.0 2023-06-21 21:38:00.391 warn You are assigning a object to the state "0_userdata.0.Geraetesteuerung.Strom.Stromzähler_untere_Wohnung.Elmo_EWE.Stromverbrauch_aktuell" which expects a number. Please fix your code to use a number or change the state type to object. This warning might become an error in future versions. javascript.0 2023-06-21 21:38:00.389 warn at processTicksAndRejections (node:internal/process/task_queues:95:5) javascript.0 2023-06-21 21:38:00.389 warn at processTicksAndRejections (node:internal/process/task_queues:95:5) javascript.0 2023-06-21 21:38:00.389 warn at processTicksAndRejections (node:internal/process/task_queues:95:5) javascript.0 2023-06-21 21:38:00.389 warn at Object.<anonymous> (script.js_.Strom.Gesamtstrom.Elmo_auslesen:18:3) javascript.0 2023-06-21 21:38:00.389 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1730:20) javascript.0 2023-06-21 21:38:00.388 warn You are assigning a object to the state "0_userdata.0.Geraetesteuerung.Strom.Stromzähler_untere_Wohnung.Elmo_EWE.Einspeisezaehlerstand_aktuell" which expects a number. Please fix your code to use a number or change the state type to object. This warning might become an error in future versions. javascript.0 2023-06-21 21:38:00.386 warn at processTicksAndRejections (node:internal/process/task_queues:95:5) javascript.0 2023-06-21 21:38:00.386 warn at Object.<anonymous> (script.js_.Strom.Gesamtstrom.Elmo_auslesen:17:3) javascript.0 2023-06-21 21:38:00.386 warn at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1730:20) javascript.0 2023-06-21 21:38:00.384 warn You are assigning a object to the state "0_userdata.0.Geraetesteuerung.Strom.Stromzähler_untere_Wohnung.Elmo_EWE.Hauptzaehlerstand_aktuell" which expects a number. Please fix your code to use a number or change the state type to object. This warning might become an error in future versions.
Das steht im Log
-
@g-hawk sagte in Parser Wert auslesen aber wie?:
You are assigning a object to the state "0_userdata.0.Geraetesteuerung.Strom.Stromzähler_untere_Wohnung.Elmo_EWE.Hauptzaehlerstand_aktuell" which expects a number. Please fix your code to use a number or change the state
da hast du einen falschen Datentyp
-
@g-hawk sagte in Parser Wert auslesen aber wie?:
7.0.3
wenn das ein update von 6.x war dann gabs da auch einen Hinweis auf "breaking changes" welche jsonata betreffen.
Weiss aber nicht mehr was das war, musste suchen,Und in Deinem LOG steht genau drin was im Skript nicht stimmt:
@g-hawk sagte in Parser Wert auslesen aber wie?:
2023-06-21 21:38:00.391 warn You are assigning a object to the state "0_userdata.0.Geraetesteuerung.Strom.Stromzähler_untere_Wohnung.Elmo_EWE.Stromverbrauch_aktuell" which expects a number. Please fix your code to use a number or change the state type to object. This warning might become an error in future versions.
und @Homoran war wieder schneller
-
@djmarc75 sagte in Parser Wert auslesen aber wie?:
wenn das ein update von 6.x war dann gabs da auch einen Hinweis auf "breaking changes" welche jsonata betreffen.
Weiss aber nicht mehr was das war, musste suchen,Wie gesagt das Blockly nochmal neu speichern - JSONATA wird dann asynchron verarbeitet.
-
@mickym
Ok ich teste -
@g-hawk sagte in Parser Wert auslesen aber wie?:
@mickym
Ok ich testeHabe gerade auf meinem Testsystem den JS Adapter aktualisiert - da solltest Du auch diese Meldung bekommen haben:
-
@mickym
Das habe ich tatsächlich gelesen aber dass das so einfach gemeint war hätte ich jetzt nicht gedacht. Aber das Problem mit dem Object und number besteht weiterhin meine Datenpunkte sind alle number.
Dann muss ja irgendwas im Skript nicht stimmen aufgrund dieser Fehlermeldung.
Was müssen wir denn da ändern? -
@g-hawk sagte in Parser Wert auslesen aber wie?:
@mickym
Das habe ich tatsächlich gelesen aber dass das so einfach gemeint war hätte ich jetzt nicht gedacht. Aber das Problem mit dem Object und number besteht weiterhin meine Datenpunkte sind alle number.
Dann muss ja irgendwas im Skript nicht stimmen aufgrund dieser Fehlermeldung.
Was müssen wir denn da ändern?Das hat aber mit JSONATA nichts zu tun - stell einfach in dem Datenpunkt der angemeckert wird den Datentyp auf number um.