Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • 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

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

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

NEWS

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

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    13
    1
    1.9k

  • Neues Video "KI im Smart Home" - ioBroker plus n8n
    BluefoxB
    Bluefox
    15
    1
    2.3k

source does not exist for "read" function

Scheduled Pinned Locked Moved Skripten / Logik
52 Posts 4 Posters 3.4k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • Thomas BraunT Thomas Braun

    @mickym

    Das ist ja genau die Frage. Wo in der Kette konvertiere ich den String am besten in ein Zahlenformat. 7
    Die Batterie schickt ein json an mosquitto, der mqtt-client holt das dann in den ioBroker rein, das ganze wird in userdata.0 geschoben und dann mit dem Alias-Adapter verwurstet.

    Wo setze ich da an?

    paul53P Offline
    paul53P Offline
    paul53
    wrote on last edited by
    #17

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

    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

    Thomas BraunT HomoranH 2 Replies Last reply
    0
    • mickymM mickym

      @thomas-braun Welche Methode hast Du verwendet?

      Thomas BraunT Online
      Thomas BraunT Online
      Thomas Braun
      Most Active
      wrote on last edited by
      #18

      @mickym

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

      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 Reply Last reply
      0
      • paul53P paul53

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

        Thomas BraunT Online
        Thomas BraunT Online
        Thomas Braun
        Most Active
        wrote on last edited by
        #19

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

        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

        1 Reply Last reply
        0
        • Thomas BraunT Thomas Braun

          @mickym

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

          mickymM Offline
          mickymM Offline
          mickym
          Most Active
          wrote on last edited by
          #20

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

          Planloses herumgeklicke von mir in der Admin-GUI.

          :grinning: :joy: :rolling_on_the_floor_laughing:

          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 Reply Last reply
          0
          • paul53P paul53

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

            HomoranH Do not disturb
            HomoranH Do not disturb
            Homoran
            Global Moderator Administrators
            wrote on last edited by Homoran
            #21

            @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

            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 Reply Last reply
            0
            • HomoranH 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 BraunT Online
              Thomas BraunT Online
              Thomas Braun
              Most Active
              wrote on last edited by
              #22

              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"
              
              

              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 Replies Last reply
              0
              • 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"
                
                
                mickymM Offline
                mickymM Offline
                mickym
                Most Active
                wrote on last edited by
                #23

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

                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 Reply Last reply
                0
                • 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 Do not disturb
                  HomoranH Do not disturb
                  Homoran
                  Global Moderator Administrators
                  wrote on last edited by 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 Reply Last reply
                  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
                    wrote on last edited by
                    #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 Replies Last reply
                    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 Do not disturb
                      HomoranH Do not disturb
                      Homoran
                      Global Moderator Administrators
                      wrote on last edited by
                      #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 Reply Last reply
                      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 Offline
                        mickymM Offline
                        mickym
                        Most Active
                        wrote on last edited by 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 Reply Last reply
                        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
                          wrote on last edited by
                          #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 Reply Last reply
                          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 Offline
                            mickymM Offline
                            mickym
                            Most Active
                            wrote on last edited by 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 Replies Last reply
                            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
                              wrote on last edited by
                              #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 Reply Last reply
                              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 Offline
                                mickymM Offline
                                mickym
                                Most Active
                                wrote on last edited by
                                #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 Reply Last reply
                                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
                                  wrote on last edited by
                                  #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 Reply Last reply
                                  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 Offline
                                    mickymM Offline
                                    mickym
                                    Most Active
                                    wrote on last edited by
                                    #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 Reply Last reply
                                    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
                                      wrote on last edited by 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 Replies Last reply
                                      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 Offline
                                        mickymM Offline
                                        mickym
                                        Most Active
                                        wrote on last edited by
                                        #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 Reply Last reply
                                        0
                                        • mickymM Offline
                                          mickymM Offline
                                          mickym
                                          Most Active
                                          wrote on last edited by 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 Reply Last reply
                                          0
                                          Reply
                                          • Reply as topic
                                          Log in to reply
                                          • Oldest to Newest
                                          • Newest to Oldest
                                          • Most Votes


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          436

                                          Online

                                          32.4k

                                          Users

                                          81.4k

                                          Topics

                                          1.3m

                                          Posts
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Login

                                          • Don't have an account? Register

                                          • Login or register to search.
                                          • First post
                                            Last post
                                          0
                                          • Home
                                          • Recent
                                          • Tags
                                          • Unread 0
                                          • Categories
                                          • Unreplied
                                          • Popular
                                          • GitHub
                                          • Docu
                                          • Hilfe