Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. Skripten / Logik
  4. source does not exist for "read" function

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    22
    1
    1.2k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.2k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.5k

source does not exist for "read" function

Geplant Angeheftet Gesperrt Verschoben Skripten / Logik
52 Beiträge 4 Kommentatoren 3.8k Aufrufe 2 Watching
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • Thomas BraunT Thomas Braun

    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"
    
    
    HomoranH Offline
    HomoranH Offline
    Homoran
    Global Moderator Administrators
    schrieb am zuletzt editiert von Homoran
    #24

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

    kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

    Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

    der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

    Thomas BraunT 1 Antwort Letzte Antwort
    0
    • HomoranH 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 BraunT Online
      Thomas BraunT Online
      Thomas Braun
      Most Active
      schrieb am zuletzt editiert von
      #25

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

      Linux-Werkzeugkasten:
      https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
      NodeJS Fixer Skript:
      https://forum.iobroker.net/topic/68035/iob-node-fix-skript
      iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

      HomoranH mickymM 2 Antworten Letzte Antwort
      0
      • Thomas BraunT Thomas Braun

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

        HomoranH Offline
        HomoranH Offline
        Homoran
        Global Moderator Administrators
        schrieb am zuletzt editiert von
        #26

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

        kein Support per PN! - Fragen im Forum stellen - es gibt fast nichts, was nicht auch für andere interessant ist.

        Benutzt das Voting rechts unten im Beitrag wenn er euch geholfen hat.

        der Installationsfixer: curl -fsL https://iobroker.net/fix.sh | bash -

        Thomas BraunT 1 Antwort Letzte Antwort
        0
        • Thomas BraunT Thomas Braun

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

          mickymM Online
          mickymM Online
          mickym
          Most Active
          schrieb am zuletzt editiert von mickym
          #27

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

          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

          1 Antwort Letzte Antwort
          0
          • HomoranH Homoran

            @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 BraunT Online
            Thomas BraunT Online
            Thomas Braun
            Most Active
            schrieb am zuletzt editiert von
            #28

            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);
            
            });
            

            Linux-Werkzeugkasten:
            https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
            NodeJS Fixer Skript:
            https://forum.iobroker.net/topic/68035/iob-node-fix-skript
            iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

            mickymM 1 Antwort Letzte Antwort
            0
            • Thomas BraunT Thomas Braun

              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);
              
              });
              
              mickymM Online
              mickymM Online
              mickym
              Most Active
              schrieb am zuletzt editiert von mickym
              #29

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

              Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

              Thomas BraunT 2 Antworten Letzte Antwort
              0
              • mickymM 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 BraunT Online
                Thomas BraunT Online
                Thomas Braun
                Most Active
                schrieb am zuletzt editiert von
                #30

                @mickym

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

                Linux-Werkzeugkasten:
                https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                NodeJS Fixer Skript:
                https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                mickymM 1 Antwort Letzte Antwort
                0
                • Thomas BraunT Thomas Braun

                  @mickym

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

                  mickymM Online
                  mickymM Online
                  mickym
                  Most Active
                  schrieb am zuletzt editiert von
                  #31

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

                  Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                  Thomas BraunT 1 Antwort Letzte Antwort
                  0
                  • mickymM 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 BraunT Online
                    Thomas BraunT Online
                    Thomas Braun
                    Most Active
                    schrieb am zuletzt editiert von
                    #32

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

                    Linux-Werkzeugkasten:
                    https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                    NodeJS Fixer Skript:
                    https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                    iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                    mickymM 1 Antwort Letzte Antwort
                    0
                    • Thomas BraunT Thomas Braun

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

                      mickymM Online
                      mickymM Online
                      mickym
                      Most Active
                      schrieb am zuletzt editiert von
                      #33

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

                      Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                      1 Antwort Letzte Antwort
                      0
                      • mickymM mickym

                        @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 BraunT Online
                        Thomas BraunT Online
                        Thomas Braun
                        Most Active
                        schrieb am zuletzt editiert von Thomas Braun
                        #34

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

                        Linux-Werkzeugkasten:
                        https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                        NodeJS Fixer Skript:
                        https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                        iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                        mickymM paul53P 2 Antworten Letzte Antwort
                        0
                        • Thomas BraunT 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.

                          mickymM Online
                          mickymM Online
                          mickym
                          Most Active
                          schrieb am zuletzt editiert von
                          #35

                          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.

                          Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                          1 Antwort Letzte Antwort
                          0
                          • mickymM Online
                            mickymM Online
                            mickym
                            Most Active
                            schrieb am zuletzt editiert von mickym
                            #36

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

                            Number(JSON.parse(val).solarbank_info.total_battery_power) *100
                            

                            Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                            1 Antwort Letzte Antwort
                            0
                            • Thomas BraunT 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.

                              paul53P Offline
                              paul53P Offline
                              paul53
                              schrieb am zuletzt editiert von
                              #37

                              @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

                              Bitte verzichtet auf Chat-Nachrichten, denn die Handhabung ist grauenhaft !
                              Produktiv: RPi 2 mit S.USV, HM-MOD-RPI und SLC-USB-Stick mit root fs

                              mickymM 1 Antwort Letzte Antwort
                              0
                              • paul53P paul53

                                @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

                                mickymM Online
                                mickymM Online
                                mickym
                                Most Active
                                schrieb am zuletzt editiert von
                                #38

                                @paul53 sagte in source does not exist for "read" function:

                                @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

                                Das mag zwar richtig sein, aber der Typ wird ja über das Skript festgelegt - zumindest ist es die Ursache, dass immer wieder auf String umgeschaltet wird und das erzeugt ja die Fehlermeldung. Die Konvertierung spielt dabei ja noch keine Rolle.

                                Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                Thomas BraunT 1 Antwort Letzte Antwort
                                0
                                • mickymM mickym

                                  @paul53 sagte in source does not exist for "read" function:

                                  @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

                                  Das mag zwar richtig sein, aber der Typ wird ja über das Skript festgelegt - zumindest ist es die Ursache, dass immer wieder auf String umgeschaltet wird und das erzeugt ja die Fehlermeldung. Die Konvertierung spielt dabei ja noch keine Rolle.

                                  Thomas BraunT Online
                                  Thomas BraunT Online
                                  Thomas Braun
                                  Most Active
                                  schrieb am zuletzt editiert von
                                  #39

                                  Das wird eher mehr als weniger...

                                  2025-02-01 16:36:56.126  - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "Number(JSON.parse(val).solarbank_info.total_battery_power) *100 "
                                  2025-02-01 16:36:56.129  - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "Number(JSON.parse(val).solarbank_info.total_battery_power) *100 "
                                  2025-02-01 16:36:56.126  - error: admin.0 (846) Invalid read function for "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power": "Number(JSON.parse(val).solarbank_info.total_battery_power) *100 " => Cannot read properties of undefined (reading 'total_battery_power')
                                  2025-02-01 16:36:56.128  - error: awtrix-light.0 (1329) Invalid read function for "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power": "Number(JSON.parse(val).solarbank_info.total_battery_power) *100 " => Cannot read properties of undefined (reading 'total_battery_power')
                                  
                                  

                                  Linux-Werkzeugkasten:
                                  https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                                  NodeJS Fixer Skript:
                                  https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                                  iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                                  mickymM 1 Antwort Letzte Antwort
                                  0
                                  • Thomas BraunT Thomas Braun

                                    Das wird eher mehr als weniger...

                                    2025-02-01 16:36:56.126  - error: history.0 (857) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "Number(JSON.parse(val).solarbank_info.total_battery_power) *100 "
                                    2025-02-01 16:36:56.129  - error: javascript.0 (888) source in "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power" does not exist for "read" function: "Number(JSON.parse(val).solarbank_info.total_battery_power) *100 "
                                    2025-02-01 16:36:56.126  - error: admin.0 (846) Invalid read function for "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power": "Number(JSON.parse(val).solarbank_info.total_battery_power) *100 " => Cannot read properties of undefined (reading 'total_battery_power')
                                    2025-02-01 16:36:56.128  - error: awtrix-light.0 (1329) Invalid read function for "alias.0.0_userdata.0.solix.solarbank_info.total_battery_power": "Number(JSON.parse(val).solarbank_info.total_battery_power) *100 " => Cannot read properties of undefined (reading 'total_battery_power')
                                    
                                    
                                    mickymM Online
                                    mickymM Online
                                    mickym
                                    Most Active
                                    schrieb am zuletzt editiert von mickym
                                    #40

                                    @thomas-braun so mit der internen Konvertierung klappt es

                                    536c7e09-7946-4cde-a141-d4da907af8e6-image.png

                                    JSON.parse(val).solarbank_info.total_battery_power *100
                                    

                                    gibt das in die Lesefunktion des Alias ein

                                    2a2628c1-d68a-461a-ad94-cf5bd4d55ff3-image.png

                                    Ich hab Dein ganzes Objekt in einen Datenpunkt geschrieben und dann im Alias extrahiert:

                                    24230fa2-0da1-4c5a-96c4-a2bdcaf639fb-image.png

                                    Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                    Thomas BraunT 1 Antwort Letzte Antwort
                                    0
                                    • mickymM mickym

                                      @thomas-braun so mit der internen Konvertierung klappt es

                                      536c7e09-7946-4cde-a141-d4da907af8e6-image.png

                                      JSON.parse(val).solarbank_info.total_battery_power *100
                                      

                                      gibt das in die Lesefunktion des Alias ein

                                      2a2628c1-d68a-461a-ad94-cf5bd4d55ff3-image.png

                                      Ich hab Dein ganzes Objekt in einen Datenpunkt geschrieben und dann im Alias extrahiert:

                                      24230fa2-0da1-4c5a-96c4-a2bdcaf639fb-image.png

                                      Thomas BraunT Online
                                      Thomas BraunT Online
                                      Thomas Braun
                                      Most Active
                                      schrieb am zuletzt editiert von
                                      #41

                                      @mickym sagte in source does not exist for "read" function:

                                      Lesefunktion des Alias ein

                                      Wo finde ich die denn?

                                      Linux-Werkzeugkasten:
                                      https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                                      NodeJS Fixer Skript:
                                      https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                                      iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                                      mickymM HomoranH 2 Antworten Letzte Antwort
                                      0
                                      • Thomas BraunT Thomas Braun

                                        @mickym sagte in source does not exist for "read" function:

                                        Lesefunktion des Alias ein

                                        Wo finde ich die denn?

                                        mickymM Online
                                        mickymM Online
                                        mickym
                                        Most Active
                                        schrieb am zuletzt editiert von mickym
                                        #42

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

                                        @mickym sagte in source does not exist for "read" function:

                                        Lesefunktion des Alias ein

                                        Wo finde ich die denn?

                                        Na unter Objekte alias.0 solltest Du doch Deinen Alias finden, deswegen brauchst auch den Adapter nicht.

                                        und der hat einen weiteren Tab:

                                        1808100c-9e55-4f2e-ad19-c2df573e4706-image.png

                                        Du kannst auch versuchen - die ganze Funktion in Deinen Adapter einzutragen - aber ich bevorzuge halt direkt im Alias Datenpunkt. Du musst halt den Haken Konvertierungsfunktion benutzen anhaken.

                                        Jeder Flow bzw. jedes Script, das ich hier poste implementiert jeder auf eigene Gefahr. Flows und Scripts können Fehler aufweisen und weder der Seitenbetreiber noch ich persönlich können hierfür haftbar gemacht werden. Das gleiche gilt für Empfehlungen aller Art.

                                        Thomas BraunT 1 Antwort Letzte Antwort
                                        1
                                        • mickymM mickym

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

                                          @mickym sagte in source does not exist for "read" function:

                                          Lesefunktion des Alias ein

                                          Wo finde ich die denn?

                                          Na unter Objekte alias.0 solltest Du doch Deinen Alias finden, deswegen brauchst auch den Adapter nicht.

                                          und der hat einen weiteren Tab:

                                          1808100c-9e55-4f2e-ad19-c2df573e4706-image.png

                                          Du kannst auch versuchen - die ganze Funktion in Deinen Adapter einzutragen - aber ich bevorzuge halt direkt im Alias Datenpunkt. Du musst halt den Haken Konvertierungsfunktion benutzen anhaken.

                                          Thomas BraunT Online
                                          Thomas BraunT Online
                                          Thomas Braun
                                          Most Active
                                          schrieb am zuletzt editiert von
                                          #43

                                          @mickym

                                          Funktioniert nicht. Wenn ich das im Alias als Konvertierung eintrage komm (NULL) dabei heraus.

                                          Linux-Werkzeugkasten:
                                          https://forum.iobroker.net/topic/42952/der-kleine-iobroker-linux-werkzeugkasten
                                          NodeJS Fixer Skript:
                                          https://forum.iobroker.net/topic/68035/iob-node-fix-skript
                                          iob_diag: curl -sLf -o diag.sh https://iobroker.net/diag.sh && bash diag.sh

                                          mickymM 1 Antwort Letzte Antwort
                                          0
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          335

                                          Online

                                          32.5k

                                          Benutzer

                                          81.7k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe