Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. Unerklärliche Werte

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

    Unerklärliche Werte

    This topic has been deleted. Only users with topic management privileges can see it.
    • paul53
      paul53 @kalle-r last edited by paul53

      @kalle-r
      Wie kommt der Wert ursprünglich in den Datenpunkt?
      Es sieht so aus, als enthielte er ein echtes Array, wie es in älteren Versionen des js-controllers und des Javascript-Adapters der Fall war. In neuen Versionen wird nach JSON gewandelt.

      K 1 Reply Last reply Reply Quote 0
      • K
        kalle-r @paul53 last edited by

        @paul53 said in Unerklärliche Werte:

        @kalle-r
        Wie kommt der Wert ursprünglich in den Datenpunkt?

        2022-12-12_12h39_10.jpg

        paul53 2 Replies Last reply Reply Quote 0
        • paul53
          paul53 @kalle-r last edited by paul53

          @kalle-r
          Du schreibst ein Array in einen Datenpunkt vom Typ "json". Kommt da keine Warnung?
          Es bleibt ein "echtes" Array. Durch manuelle Eingaben wird es zu einem String und damit unbrauchbar.

          EDIT: Habe mal getestet:

          • Erst ein Array mit Zahlen und Datenpunkttyp "array" manuell eine Zahl hinzugefügt: Es bleibt ein Array mit zusätzlichem Element (wird automatisch gewandelt)
          • Dann das gleiche Array mit Zahlen und Datenpunkttyp "json": Es wurde nach manueller Eingabe einer zusätzlichen Zahl zu einem JSON(String), wird also nicht gewandelt.

          Schlussfolgerung: Ändere den Typ in "array"! Dann kann der Datenpunktwert auch editiert werden, da er ein JSON enthält, das beim Einlesen automatisch in ein Array gewandelt wird.

          1 Reply Last reply Reply Quote 0
          • paul53
            paul53 @kalle-r last edited by

            @kalle-r
            Der richtige Umgang mit einem Datenpunkt vom Typ "json" wäre:

            Bild_2022-12-12_134018183.png

            1 Reply Last reply Reply Quote 0
            • paul53
              paul53 @kalle-r last edited by paul53

              @kalle-r sagte: Beim Erzeugen hab ich jedenfalls JSON ausgewählt

              Habe PR auf Github erstellt, damit auch "array" ausgewählt werden kann. In älteren Admin-Versionen war das der Fall.

              1 Reply Last reply Reply Quote 1
              • K
                kalle-r last edited by

                @paul53
                Danke mal für Deine Erklärungen. Den korrekten Umgang mit dem json kenne ich schon, da hast Du mir ja neulich auch schon geholfen.
                Warnung hab ich keine bekommen. (Oder ich hab die einfach nicht wahrgenommen 😳
                Hab jetzt den Datenpunkt gelöscht und neu als Array angelegt, funktioniert soweit alles erstmal.
                Trotzdem kann ich mir immer noch nicht erklären woher die zusätzlichen Zahlen gekommen sind die nicht im Datenpunkt
                angezeigt wurden. Wird vermutlich ein ungelöstes Rätsel bleiben.....

                1 Reply Last reply Reply Quote 0
                • K
                  kalle-r last edited by

                  Das Thema ist leider noch nicht durch.... Ich verstehe nicht was da passiert....
                  hab einen Datenpunkt vom Typ array angelegt

                  2022-12-15_10h01_33.jpg

                  und schonmal einen Wert 5 rein geschrieben

                  2022-12-15_10h01_11.jpg

                  mein Blockly

                  2022-12-15_10h00_05.jpg

                  die Ausgabe vom ersten Programmdurchlauf ist klar

                  2022-12-15_10h02_21.jpg

                  beim zweiten Durchlauf tritt jetzt das unerklärliche Verhalten auf:

                  2022-12-15_10h02_38.jpg

                  die Ausgabe müsste doch eigentlich die gleiche sein wie im ersten Durchlauf?

                  wenn ich nun ein Skript starte mit der der Datenpunkt in eine ganz andere Variable gelesen wird

                  2022-12-15_10h03_07.jpg

                  sieht man daß das erste Skript offenbar den Datenpunkt selber verändert
                  obwohl da weder "aktualisiere" noch "steuere" des Datenpunktes enthalten ist

                  2022-12-15_10h03_19.jpg

                  Unter "Objekte" hat sich aber die Anzeige im Datenpunkt selber nicht verändert

                  2022-12-15_10h03_37.jpg

                  Wie läßt sich dieses Verhalten erklären?

                  Homoran paul53 2 Replies Last reply Reply Quote 0
                  • Homoran
                    Homoran Global Moderator Administrators @kalle-r last edited by

                    @kalle-r sagte in Unerklärliche Werte:

                    mein Blockly

                    ist das alles? sonst nichts auf der Arbeitsfläche?

                    @kalle-r sagte in Unerklärliche Werte:

                    schonmal einen Wert 5 rein geschrieben

                    wieso ist Wertetyp leer?

                    @kalle-r sagte in Unerklärliche Werte:

                    Wie läßt sich dieses Verhalten erklären?

                    hast du mal

                    • den Browsercache gelöscht?
                    • den js Adapter neu gestartet?
                    K 1 Reply Last reply Reply Quote 0
                    • K
                      kalle-r @Homoran last edited by kalle-r

                      @homoran

                      das ist alles... mehr ist nicht auf der Arbeitsfläche

                      wenn ich einen Datenpunkt anlege kann ich array auswählen

                      2022-12-15_10h51_06.jpg

                      danach beim modifizieren gibt's den Typ nicht mehr

                      2022-12-15_10h51_49.jpg

                      darum ist das Feld vermutlich leer

                      Adapter neu gestartet.
                      Hab grad mal das ganze in einem anderen Browser gestartet... gleiches Verhalten

                      N 1 Reply Last reply Reply Quote 0
                      • paul53
                        paul53 @kalle-r last edited by paul53

                        @kalle-r sagte: Wie läßt sich dieses Verhalten erklären?

                        Gar nicht, es sei denn, es ist ein Skript unter der Gruppe "global" aktiv.

                        1 Reply Last reply Reply Quote 0
                        • N
                          Nordischerjung @kalle-r last edited by

                          @kalle-r das ist ja komisch,
                          ich habe es auch mal nachgebaut und ein das Script getartet/gestoppt. Es werden immer mehr, selbst in dem DP laut Debug

                          d1f8194a-cb55-4689-b15f-8f0ef9187f4a-grafik.png

                          123a8a30-b196-4840-be6a-36d80baeec65-grafik.png

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

                            @nordischerjung dann müsste die Variable Liste ja den Neustart überleben.
                            mal zu Beginn (vor dem Einlesen) einen debug gesetzt?

                            N Codierknecht 2 Replies Last reply Reply Quote 0
                            • N
                              Nordischerjung @Homoran last edited by Nordischerjung

                              @homoran dann kommt undefined

                              5f2baee9-0157-4f95-8ad0-a3aa0f40e8f1-grafik.png

                              Warum wird der DP denn immer erhöht? Der wird doch nirgends beschrieben.

                              11a530e0-33a9-4f9b-93af-0dc489841e39-grafik.png

                              Edit ich hatte die Var einfach mal zu testzwecken umbenannt

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

                                @nordischerjung sagte in Unerklärliche Werte:

                                Warum wird der DP denn immer erhöht? Der wird doch nirgends beschrieben.

                                und selbst wenn, wie bei @kalle-r , ändert sich der Wert darin nicht.

                                K 1 Reply Last reply Reply Quote 0
                                • K
                                  kalle-r @Homoran last edited by kalle-r

                                  @homoran

                                  wie oben geschrieben, für mich schaut das so aus als ob durch das Skript "irgendwo" der Datenpunkt selber
                                  beeinflusst wird.
                                  Im Datenpunkt (unter Objekte) werden die geänderten Werte nicht angezeigt aber wenn ich per Skript den Wert des Datenpunktes
                                  ausgeben lasse dann stehen da Werte drin die ich nirgendwo sehe.
                                  Ich denke da ist irgendwo ein Bug versteckt....
                                  Das kleine Testskript oben hab ich nur gebaut weil ich schon länger (siehe ganz oben) mit unerklärlichen Werten
                                  kämpfe und bisher keine Idee hatte wo die herkommen.
                                  Jetzt hab ich das zumindest so weit reduziert daß das (siehe auch der Post von @Nordischerjung) problemlos nachvollziehbar ist. Ich werd die überzähligen Werte in meinem eigentlichen Hauptskript jetzt automatisch
                                  löschen lassen. Trotzdem sollte das vermutlich mal debuggt werden was da passiert...

                                  paul53 1 Reply Last reply Reply Quote 0
                                  • paul53
                                    paul53 @kalle-r last edited by

                                    @kalle-r sagte: durch das Skript "irgendwo" der Datenpunkt selber beeinflusst wird.

                                    Habe es auch getestet: Es sieht so aus, dass der Wert im Puffer der Javascript-Instanz verändert wird, da Arrays per Referenz übergeben werden.

                                    1 Reply Last reply Reply Quote 1
                                    • Codierknecht
                                      Codierknecht Developer Most Active @Homoran last edited by

                                      @homoran
                                      Kann ich zumindest so bestätigen:
                                      8111f835-2e45-4846-b3f9-ca2189ff5d08-image.png
                                      Überlebt natürlich einen Neustart der JS-Instanz nicht und in den DP wird auch nix geschrieben.
                                      Aber solange die Instanz lebt, wird weiter fleißig hinzugefügt.

                                      paul53 1 Reply Last reply Reply Quote 1
                                      • paul53
                                        paul53 @Codierknecht last edited by paul53

                                        @codierknecht sagte: Überlebt natürlich einen Neustart der JS-Instanz nicht

                                        Das zeigt auch, dass Veränderungen im Array im States-Puffer der Javascript-Instanz erfolgen. Die Variable enthält die Referenz auf das Array im Puffer.

                                        K 1 Reply Last reply Reply Quote 1
                                        • K
                                          kalle-r @paul53 last edited by kalle-r

                                          @paul53
                                          Kann man diesen Puffer per Skript leeren?
                                          Oder anders gefragt:
                                          Wie kann man denn nun wirklich nur den Inhalt des Datenpunktes in eine Variable bekommen?

                                          paul53 Codierknecht 2 Replies Last reply Reply Quote 0
                                          • paul53
                                            paul53 @kalle-r last edited by paul53

                                            @kalle-r sagte: Wie kann man denn nun wirklich nur den Inhalt des Datenpunktes in eine Variable bekommen?

                                            Das komplette Array in eine Variable kopieren.

                                            Bild_2022-12-15_185523658.png

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            887
                                            Online

                                            31.9k
                                            Users

                                            80.1k
                                            Topics

                                            1.3m
                                            Posts

                                            6
                                            39
                                            1283
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo