Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. source does not exist for "read" function

    NEWS

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    source does not exist for "read" function

    This topic has been deleted. Only users with topic management privileges can see it.
    • Thomas Braun
      Thomas Braun Most Active @mickym last edited by

      @mickym

      Ich kann es wirklich nicht sagen.
      Planloses herumgeklicke von mir in der Admin-GUI.

      mickym 1 Reply Last reply Reply Quote 0
      • Thomas Braun
        Thomas Braun Most Active @paul53 last edited by

        @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.

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

          @thomas-braun sagte in source does not exist for "read" function:

          Planloses herumgeklicke von mir in der Admin-GUI.

          😀 😂 🤣

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

            @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

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

              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"
              
              
              mickym Homoran 2 Replies Last reply Reply Quote 0
              • mickym
                mickym Most Active @Thomas Braun last edited by

                @thomas-braun na wenn du aber auf mixed umstellst, dann sollte der Fehler nicht mehr kommen

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

                  @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?

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

                    @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.

                    Homoran mickym 2 Replies Last reply Reply Quote 0
                    • Homoran
                      Homoran Global Moderator Administrators @Thomas Braun last edited by

                      @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 1 Reply Last reply Reply Quote 0
                      • mickym
                        mickym Most Active @Thomas Braun last edited by mickym

                        @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.

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

                          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);
                          
                          });
                          
                          mickym 1 Reply Last reply Reply Quote 0
                          • mickym
                            mickym Most Active @Thomas Braun last edited by mickym

                            @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.

                            Thomas Braun 2 Replies Last reply Reply Quote 0
                            • Thomas Braun
                              Thomas Braun Most Active @mickym last edited by

                              @mickym

                              Danke, hab da keinen Bock mehr drauf dran herumzufrickeln.
                              Das bleibt jetzt so. Steht halt im echart statt xy% 0,xy%

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

                                @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.

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

                                  @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.

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

                                    @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.

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

                                      @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.

                                      mickym paul53 2 Replies Last reply Reply Quote 0
                                      • mickym
                                        mickym Most Active @Thomas Braun last edited by

                                        Um welchen Wert handelt es sich - ich hab das mal schön formatiert:

                                        {
                                          "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": "AZV6Y60D30400300",
                                                "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-cb80eb3bcc29",
                                          "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
                                        }
                                        

                                        Es scheint mir das zu sein - und da sind alle Werte Strings

                                        f9933a98-40f9-4b71-9dfe-8feee08661b9-image.png

                                        einen Augenblick bitte.

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

                                          So dann probiere mal in der Konvertierungsfunktion für den Alias folgendes:

                                          Number(JSON.parse(val).solarbank_info.total_battery_power) *100
                                          
                                          1 Reply Last reply Reply Quote 0
                                          • paul53
                                            paul53 @Thomas Braun last edited by

                                            @thomas-braun sagte: "total_battery_power":"0.71" dürfte die Ursache sein.

                                            Das ist nicht die Ursache, denn es findet bei Multiplikation eine implizite Wandlung statt:

                                            JS_Multiplikation_String.JPG

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            933
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            4
                                            52
                                            1088
                                            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