NEWS
source does not exist for "read" function
-
Ich glaube, jetzt geht es...
Hab noch 'irgendwo irgendwas' umgestellt, jetzt erscheint auch im echarts der richtige Prozentwert.
Mal schauen ob es einen Neustart auch übersteht... -
@thomas-braun Welche Methode hast Du verwendet?
-
@thomas-braun sagte: Wo in der Kette konvertiere ich den String am besten in ein Zahlenformat
Die Multiplikation mit 100 im Alias konvertiert implizit den String in eine Zahl.
Die Meldung "does not exist" sieht eher danach aus, als dass es den DP "0_userdata.0.solix.solarbank_info.total_battery_power" nicht (mehr) gibt. -
Ich kann es wirklich nicht sagen.
Planloses herumgeklicke von mir in der Admin-GUI. -
@paul53 sagte in source does not exist for "read" function:
Die Meldung "does not exist" sieht eher danach aus, als dass es den DP "0_userdata.0.solix.solarbank_info.total_battery_power" nicht (mehr) gibt.
Doch, den gibt und gab es.
-
@thomas-braun sagte in source does not exist for "read" function:
Planloses herumgeklicke von mir in der Admin-GUI.
-
@paul53 sagte in source does not exist for "read" function:
nicht (mehr) gibt.
das hatte ich etwas differenzierter interpretiert, da die Meldung noch mit 'for read' weiterging.
Dachte daher dass der read=false sei, was er nicht ist.Möglich aber, dass es nur um den in der Lesekonvertierung angegebenen DP geht
-
Leider nix. Mein Log wird immer noch geflutet:
2025-02-01 15:44:53.948 - warn: javascript.0 (888) You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions. 2025-02-01 15:44:53.949 - warn: javascript.0 (888) at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2090:20) 2025-02-01 15:44:53.950 - warn: javascript.0 (888) at createObjectsRecursively (script.js.solix2mqtt:74:11) 2025-02-01 15:44:53.950 - warn: javascript.0 (888) at createObjectsRecursively (script.js.solix2mqtt:38:9) 2025-02-01 15:44:53.950 - warn: javascript.0 (888) at Object.<anonymous> (script.js.solix2mqtt:84:4) 2025-02-01 15:44:53.950 - warn: javascript.0 (888) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1452:38) 2025-02-01 15:44:53.950 - warn: javascript.0 (888) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:645:29) 2025-02-01 15:44:53.950 - warn: javascript.0 (888) at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.ts:11048:62) 2025-02-01 15:44:53.950 - warn: javascript.0 (888) at processImmediate (node:internal/timers:483:21) 2025-02-01 15:44:54.003 - info: javascript.0 (888) State value to set for "0_userdata.0.solix.solarbank_info.total_battery_power" has to be type "number" but received type "string" 2025-02-01 15:44:54.066 - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100" 2025-02-01 15:44:54.066 - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100" 2025-02-01 15:45:53.952 - warn: javascript.0 (888) You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number. Please fix your code to use a number or change the state type to string. This warning might become an error in future versions. 2025-02-01 15:45:53.954 - warn: javascript.0 (888) at setState (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:2090:20) 2025-02-01 15:45:53.954 - warn: javascript.0 (888) at createObjectsRecursively (script.js.solix2mqtt:74:11) 2025-02-01 15:45:53.954 - warn: javascript.0 (888) at createObjectsRecursively (script.js.solix2mqtt:38:9) 2025-02-01 15:45:53.954 - warn: javascript.0 (888) at Object.<anonymous> (script.js.solix2mqtt:84:4) 2025-02-01 15:45:53.955 - warn: javascript.0 (888) at Object.callback (/opt/iobroker/node_modules/iobroker.javascript/lib/sandbox.js:1452:38) 2025-02-01 15:45:53.955 - warn: javascript.0 (888) at Object.stateChange (/opt/iobroker/node_modules/iobroker.javascript/main.js:645:29) 2025-02-01 15:45:53.955 - warn: javascript.0 (888) at Immediate._onImmediate (/opt/iobroker/node_modules/@iobroker/js-controller-adapter/src/lib/adapter/adapter.ts:11048:62) 2025-02-01 15:45:53.955 - warn: javascript.0 (888) at processImmediate (node:internal/timers:483:21) 2025-02-01 15:45:54.007 - info: javascript.0 (888) State value to set for "0_userdata.0.solix.solarbank_info.total_battery_power" has to be type "number" but received type "string" 2025-02-01 15:45:54.074 - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100" 2025-02-01 15:45:54.074 - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "val*100"
-
@thomas-braun na wenn du aber auf mixed umstellst, dann sollte der Fehler nicht mehr kommen
-
@thomas-braun sagte in source does not exist for "read" function:
You are assigning a string to the state "0_userdata.0.solix.solarbank_info.total_battery_power" which expects a number
woher bekommt der DP seinen Wert
wie sehen denn die beiden angemeckerten alias-Konfigurationen aus?
-
@homoran sagte in source does not exist for "read" function:
woher bekommt der DP seinen Wert
Aus einem JSON, das zuvor aber noch über ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.
-
@thomas-braun sagte in source does not exist for "read" function:
ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.
zei gen!
-
@thomas-braun sagte in source does not exist for "read" function:
@homoran sagte in source does not exist for "read" function:
woher bekommt der DP seinen Wert
Aus einem JSON, das zuvor aber noch über ein enstprechendes Skript läuft und dann dort in Einzelwerte zerlegt wird.
Na dann ist es doch das Skript - und wenn Du schon mit Alias arbeitest, dann würde ich es auch nicht über Einzelwerte vorher zerlegen, sondern direkt im Alias auseinandernehmen.
Von einem Skript hast Du vorher ja gar nichts gesagt.
Ausser Du nimmst meinen NodeRed Flow - der zerlegt auch in die richtigen Datentypen.Aber Spaß beiseite - ich würde nichts auseinander nehmen sondern das Objekt speichern und im Alias auseinandernehmen.
-
Das 'Konvertier'-Skript:
// where the mqtt messages arrive const mqttDatenpunktObjectId = 'mqtt.0.solix.site.Stromstausee.scenInfo'; // where the states should appear const userDataFolder = '0_userdata.0.solix'; // ############## end user config // receive on(mqttDatenpunktObjectId, (obj) => { // log(JSON.stringify(obj.state.val)) const jsonString = obj.state.val; const jsonData = JSON.parse(jsonString); function createObjectsRecursively(parent, data) { for (const key in data) { const obj = data[key]; const stateName = `${parent}.${key}`; if (typeof obj === 'object') { createObjectsRecursively(stateName, obj); } else { let value = obj; // Check if the state already exists. If it does, just update the value. // If it does not exist create the states. if (!existsState(stateName)) { // If the state does not exist, create it and set the value createState(stateName, value, { name: key, type: typeof value, role: "value", read: true, write: true }); log(`Created state ${stateName}`); } else { // log(stateName + ': ' + value) setState(stateName, value, true); } } } } createObjectsRecursively(userDataFolder, jsonData); });
-
@thomas-braun sagte in source does not exist for "read" function:
type: typeof value,
das stellt das immer wieder zurück. Es kann ja sein, dass im Objekt ein Komma anstelle eines Dezimalpunktes steht und schon kann dieses Skript nicht funktionieren.
Wie gesagt ich würde als schnelle Massnahme - ohne hier lange im Script rumzusuchen oder warum das Skript immer wieder umstellt, im Alias direkt das Objekt aus
mqtt.0.solix.site.Stromstausee.scenInfo
auslesen. Das sind ja alles Infos, die vorher nicht da waren und ich bin davon ausgegangen, dass das so direkt aus mosquitto kommt, was es aber nicht tut.
Also poste lieber mal das Objekt und dann extrahieren wir das im Alias.
-
Danke, hab da keinen Bock mehr drauf dran herumzufrickeln.
Das bleibt jetzt so. Steht halt im echart statt xy% 0,xy% -
@thomas-braun Was ist den schlimm dieses Objekt zu posten, also den Wert von
mqtt.0.solix.site.Stromstausee.scenInfo
Aber wenn Du keine Lust hast, dann halt nicht.
-
@mickym sagte in source does not exist for "read" function:
Es kann ja sein, dass im Objekt ein Komma anstelle eines Dezimalpunktes steht
Das könnte sogar sein. Im rohen JSON steht der Wert mit Dezimalpunkt drin, nicht mit Komma.
Möglich, das es von Anker bei einem Update geändert wurde. Bis vor ein paar Tagen hat das nämlich so funktioniert und ich habe da selber nix verändert. -
@thomas-braun sagte in source does not exist for "read" function:
Das könnte sogar sein. Im rohen JSON steht der Wert mit Dezimalpunkt drin, nicht mit Komma.
Na also war doch meine Vermutung richtig. Also musst du das Komma durch einen Punkt ersetzen und dann kann man es im Alias richtig verwenden. Deswegen poste halt das Objekt - das Skript wird Dir das niemals lösen, da eine Zahl mit einem Dezimalkomma immer als String erkannt wird.
-
@mickym sagte in source does not exist for "read" function:
Was ist den schlimm dieses Objekt zu posten,
Nix.
{"home_info":{"home_name":"Home","home_img":"","charging_power":"0.00","power_unit":"W"},"solar_list":[],"pps_info":{"pps_list":[],"total_charging_power":"0.00","power_unit":"W","total_battery_power":"0.00","updated_time":"","pps_status":0},"statistics":[{"type":"1","total":"289.00","unit":"kwh"},{"type":"2","total":"288.13","unit":"kg"},{"type":"3","total":"115.60","unit":"€"}],"topology_type":"1","solarbank_info":{"solarbank_list":[{"device_pn":"A17C0","device_sn":"AZB6Y60D40400300","device_name":"Solarbank E1600","device_img":"https://public-aiot-fra-prod.s3.dualstack.eu-central-1.amazonaws.com/anker-power/public/product/2024/05/10/iot-admin/FycLLqjHpYf0Bdab/20230719-144818.png","battery_power":"71","bind_site_status":"","charging_power":"61","power_unit":"W","charging_status":"1","status":"1","wireless_type":"1","main_version":"","photovoltaic_power":"61","output_power":"61","create_time":1721841629,"set_load_power":"","sub_package_num":0,"output_cutoff_data":10,"is_display":true,"bat_charge_power":"0"}],"total_charging_power":"0","power_unit":"W","charging_status":"0","total_battery_power":"0.71","updated_time":"2025-02-01 16:17:55","total_photovoltaic_power":"61","total_output_power":"61.00","display_set_power":false,"battery_discharge_power":"0","ac_power":"0","to_home_load":"0","is_display_data":true,"solar_power_1":"0","solar_power_2":"0","solar_power_3":"0","solar_power_4":"0","other_input_power":"0","micro_inverter_power":"61","micro_inverter_power_limit":"0","micro_inverter_low_power_limit":"0","grid_to_battery_power":"0","pei_heating_power":"0","backup_info":{"start_time":0,"end_time":0,"full_time":0}},"retain_load":"150W","scene_mode":0,"home_load_power":"0","updated_time":"01-01-0001 00:00:00","power_site_type":2,"site_id":"a26d801a-afc6-45c0-bb93-ab80ab3bcc29","powerpanel_list":[],"grid_info":null,"is_downgrade":false,"error_code":0,"smart_plug_info":null,"feature_switch":null,"other_loads_power":"0","priority_discharge_switch":0,"display_priority_discharge_tips":0,"priority_discharge_upgrade_devices":"","style_id":0,"is_show_priority_discharge":1}
"total_battery_power":"0.71"
dürfte die Ursache sein.