Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. Blockly Prüfung auf "null"?

    NEWS

    • ioBroker goes Matter ... Matter Adapter in Stable

    • 15. 05. Wartungsarbeiten am ioBroker Forum

    • Monatsrückblick - April 2025

    Blockly Prüfung auf "null"?

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

      @flitzpiepe sagte: null:

      "null" als String ergibt wahr bei er impliziten Typwandlung.

      1 Reply Last reply Reply Quote 0
      • F
        flitzpiepe last edited by

        @paul53 said in Blockly Prüfung auf "null"?:

        @flitzpiepe sagte: null:

        "null" als String ergibt war bei er impliziten Typwandlung.

        ok, es scheint, dass da bei mir irgendwo jemand auf der Leitung steht, da ich mir auch nach mehrmaligem Lesen der Info nicht erschließen kann, was gemeint sein könnte und wie ich letztendlich einen funktionierenden null check erreiche.
        Hier ging es auch um dieses Thema und die Abfrage war m.E. so formuliert wie bei mir.

        Habe es jetzt anders für mich gelöst und prüfe, ob die Länge des Strings > 5 ist. true: Wert vorhanden bei false: kein Wert vorhanden.

        Asgothian 1 Reply Last reply Reply Quote 0
        • Asgothian
          Asgothian Developer @flitzpiepe last edited by

          @flitzpiepe sagte in Blockly Prüfung auf "null"?:

          @paul53 said in Blockly Prüfung auf "null"?:

          @flitzpiepe sagte: null:

          "null" als String ergibt war bei er impliziten Typwandlung.

          ok, es scheint, dass da bei mir irgendwo jemand auf der Leitung steht, da ich mir auch nach mehrmaligem Lesen der Info nicht erschließen kann, was gemeint sein könnte und wie ich letztendlich einen funktionierenden null check erreiche.
          Hier ging es auch um dieses Thema und die Abfrage war m.E. so formuliert wie bei mir.

          Habe es jetzt anders für mich gelöst und prüfe, ob die Länge des Strings > 5 ist. true: Wert vorhanden bei false: kein Wert vorhanden.

          Ich versuch mal dich von dem Schlauch zu holen:

          Wenn du im ioBroker "null" stehen siehst, dann kann das auf 2 Arten passieren:

          • der Datenpunkt hat den expliziten Wert null.
          • im Datenpunkt steht der Text "null".

          Die von Dir im Skript oben eingebaute Überprüfung prüft auf den expliziten Wert null, das worauf du prüfen möchtest ist aber der Text "null"

          Nun zum Thema Vergleich:
          Im Kontext Falls Wert mache wird Wert als wahr angesehen wenn

          • Wert ein Text mit einem oder mehr Zeichen ist ("null", "leer", "hierstehtwas", "1", " ")
          • Wert eine Zahl ist die nicht 0 ist
          • Wert explizit wahr beinhaltet
          • Wert einen der beiden intern definierten Werte NaN und infinity beinhaltet (diese entstehen automatisch bei mathematischen Operationen die ungültig sind, z.Bsp. 1/0 oder sqrt(-2)

          Im Kontext Falls Wert mache wird Wert als falsch angesehen wenn

          • Wert ein Text ohne Zeichen ist ("")
          • Wert die Zahl 0 ist
          • Wert explizit falsch beinhaltet
          • Wert einen dieser intern definierten Werte beinhaltet: null, undefined

          Nun dazu wie du auf den Text "null" prüfen kannst: In deinem Originalen Blockly ersetzt du den Baustein mit null durch einen mit dem Text "null".

          A.

          F 1 Reply Last reply Reply Quote 0
          • F
            flitzpiepe @Asgothian last edited by

            @asgothian said in Blockly Prüfung auf "null"?:

            @flitzpiepe sagte in Blockly Prüfung auf "null"?:

            @paul53 said in Blockly Prüfung auf "null"?:

            @flitzpiepe sagte: null:

            "null" als String ergibt war bei er impliziten Typwandlung.

            ok, es scheint, dass da bei mir irgendwo jemand auf der Leitung steht, da ich mir auch nach mehrmaligem Lesen der Info nicht erschließen kann, was gemeint sein könnte und wie ich letztendlich einen funktionierenden null check erreiche.
            Hier ging es auch um dieses Thema und die Abfrage war m.E. so formuliert wie bei mir.

            Habe es jetzt anders für mich gelöst und prüfe, ob die Länge des Strings > 5 ist. true: Wert vorhanden bei false: kein Wert vorhanden.

            Ich versuch mal dich von dem Schlauch zu holen:

            Nun dazu wie du auf den Text "null" prüfen kannst: In deinem Originalen Blockly ersetzt du den Baustein mit null durch einen mit dem Text "null".

            A.

            Hi,
            danke für den ausführlichen Kommentar und ich denke wir nähern uns dem Problem:
            Das bedeute aber auch, dass die Zuweisungen:

            0dfd719d-0efd-4844-bbe8-13e83b641d9e-image.png

            ... ein und dasselbe aussagen? Davon bin ich bisher nicht ausgegangen und da lag dann mein Gedankenfehler? Ich dachte vom Block null wird der Datenpunkt auf den expliziten Wert null gesetzt und von der String-Zuweisung erhält der Datenpunkt den String "null". Ich habe den Block null in der Zuweisung verwendet und deswegen auch mit dem Block auf null geprüft.

            Im Java-ScriptCode:

                setState("javascript.0.scriptEnabled.System.PushOver.PushOverSysVar.PushOver_File"/*varPushOver_File*/, null, true);
                setState("javascript.0.scriptEnabled.System.PushOver.PushOverSysVar.PushOver_File"/*varPushOver_File*/, 'null', true);
            

            ... ist hier ja auch der Unterschied zu sehen durch Verwendung der Anführungszeichen bei String-Zuweisung.

            Ist hier meine eigentliche Frage vielleicht, warum mein Datenpunkt nicht auf den expliziten Wert null gesetzt wurde, obwohl ich die Zuweisung über den null-Block gemacht habe?

            Asgothian paul53 2 Replies Last reply Reply Quote 0
            • Asgothian
              Asgothian Developer @flitzpiepe last edited by

              @flitzpiepe sagte in Blockly Prüfung auf "null"?:

              i,
              danke für den ausführlichen Kommentar und ich denke wir nähern uns dem Problem:
              Das bedeute aber auch, dass die Zuweisungen:

              ... ein und dasselbe aussagen? Davon bin ich bisher nicht ausgegangen und da lag dann mein Gedankenfehler?

              Nein, diese Zuweisungen sind nicht identisch. Die erste weist dem State den Wert null zu, der zweite den text "null". Allerdings kann es sein das der JS-Controller eine Typconvertierung vornimmt da der Datenpunkt als "string" angelegt ist.

              Du solltest im Übrigen (sofern du den aktuellen JS Controller mit Admin 5 nutzt eine Warnmeldung bekommen wenn du versuchst null in einen State zu schreiben der als "string" definiert ist.

              A.

              1 Reply Last reply Reply Quote 0
              • paul53
                paul53 @flitzpiepe last edited by

                @flitzpiepe sagte: obwohl ich die Zuweisung über den null-Block gemacht habe?

                Da der Datenpunkt von Typ "string" ist, ist die Zuweisung von null (Typ "object") falsch. Um ihn zu löschen, weise einen Leerstring zu. Dann funktioniert ebenfalls die Prüfung "falls Wert von DP" , da die implizite Typwandlung des Leerstrings false ergibt.

                1 Reply Last reply Reply Quote 0
                • N
                  niiccooo1 last edited by niiccooo1

                  [GELÖST]
                  Hallo Zusammen,

                  ich knüpfe mal an das Thema an, da ich an einem ähnlichen Punkt bin, aber ich einfach nicht weiter komme.
                  Ich möchte ebenfalls eine Abfrage auf null / kein Inhalt überprüfen. Es handelt sich bei mir jedoch um eine Abfrage aus der InfluxDB.
                  Über ein Javascript lasse ich mir aus dem InfluxDB folgendes Ergebnis als JSON ausgeben:

                  {"result":[[{"result":"_result","table":0,"_start":"2024-10-10T06:45:18.1890708Z","_stop":"2024-10-10T07:45:18.1890708Z","_time":"2024-10-10T07:45:18.0914702Z","_value":-1536525,"_field":"T0201","_measurement":"VST3","ts":1728546318091},{"result":"_result","table":1,"_start":"2024-10-10T06:45:18.1890708Z","_stop":"2024-10-10T07:45:18.1890708Z","_time":"2024-10-10T07:45:18.0914702Z","_value":22.59207,"_field":"T0202","_measurement":"VST3","ts":1728546318091},{"result":"_result","table":2,"_start":"2024-10-10T06:45:18.1890708Z","_stop":"2024-10-10T07:45:18.1890708Z","_time":"2024-10-10T07:45:18.0914702Z","_value":22.78723,"_field":"T0203","_measurement":"VST3","ts":1728546318091},{"result":"_result","table":3,"_start":"2024-10-10T06:45:18.1890708Z","_stop":"2024-10-10T07:45:18.1890708Z","_time":"2024-10-10T07:45:18.0914702Z","_value":22.32642,"_field":"T0204","_measurement":"VST3","ts":1728546318091},{"result":"_result","table":4,"_start":"2024-10-10T06:45:18.1890708Z","_stop":"2024-10-10T07:45:18.1890708Z","_time":"2024-10-10T07:45:18.0914702Z","_value":22.2529,"_field":"T0205","_measurement":"VST3","ts":1728546318091},{"result":"_result","table":5,"_start":"2024-10-10T06:45:18.1890708Z","_stop":"2024-10-10T07:45:18.1890708Z","_time":"2024-10-10T07:45:18.0914702Z","_value":-1669286,"_field":"T0206","_measurement":"VST3","ts":1728546318091},{"result":"_result","table":6,"_start":"2024-10-10T06:45:18.1890708Z","_stop":"2024-10-10T07:45:18.1890708Z","_time":"2024-10-10T07:45:18.0914702Z","_value":-2018108,"_field":"T0207","_measurement":"VST3","ts":1728546318091}]],"ts":1728546318199,"error":null}
                  

                  Anschließend filtere ich über folgendes Blockly mir den Feldnamen aus:
                  8f4326a2-a10b-4a0f-8468-ef41e3f6cbc7-image.png

                  "j" ist meine Zählvariable welche über eine Schleife hochgezählt wird und "ergebnis" das oben gezeigte JSON

                  Nun möchte ich über die Schleife den value an einen Datenpunkt geben solange bis die Filterung keinen weiteren Feldname mehr findet. Ich bekomme diese Überprüfung nicht hin.

                  Ich habe probiert es über null zu vergleichen, über db66cdc2-c9c8-4f95-a27a-de17a205d2ef-image.png

                  Folgendes klappt auch nicht:
                  af809b1f-a86c-4ef7-8178-f819f19011a0-image.png

                  Was mir aufgefallen ist, dass sich der Typ von string nach object ändert sobald kein Inhalt mehr da ist.

                  cdb267aa-1669-40a2-80d6-d3eb9294c6e5-image.png

                  Log:

                  javascript.0	09:54:41.561	info	script.js.ESPEasy.Test: Typ von: string:T0204
                  javascript.0	09:54:42.571	info	script.js.ESPEasy.Test: Typ von: string:T0205
                  javascript.0	09:54:43.587	info	script.js.ESPEasy.Test: Typ von: string:T0206
                  javascript.0	09:54:44.595	info	script.js.ESPEasy.Test: Typ von: string:T0207
                  javascript.0	09:54:45.603	info	script.js.ESPEasy.Test: Typ von: object:
                  javascript.0	09:54:46.606	info	script.js.ESPEasy.Test: Typ von: object:
                  

                  Kann mir jemand helfen?

                  Codierknecht N 2 Replies Last reply Reply Quote 0
                  • Codierknecht
                    Codierknecht Developer Most Active @niiccooo1 last edited by Codierknecht

                    @niiccooo1

                    Das hier funktioniert:

                    b91923da-8277-4b81-a5f1-a6db8a540083-image.png
                    Aber da sind ja auch alle Pärchen sauber gefüllt.

                    Edit

                    meine Zählvariable welche über eine Schleife hochgezählt wird

                    Die Frage wäre: Wie hast Du Deine Schleife konstruiert?

                    N 1 Reply Last reply Reply Quote 0
                    • N
                      Nordischerjung @niiccooo1 last edited by

                      @niiccooo1 kann der hier helfen?

                      8443033b-1fd6-4eb3-837b-5fb6b311e9bb-image.png

                      N 1 Reply Last reply Reply Quote 0
                      • N
                        niiccooo1 @Codierknecht last edited by

                        @codierknecht
                        Die Schleife habe ich so aufgebaut:
                        9c6ef13a-6784-47ef-b63b-ca57d5abe293-image.png

                        Wobei die Prüfung nicht funktioniert hat.

                        Dein Vorschlag funktioniert wunderbar 🙂

                        Vielen Dank!

                        Codierknecht 1 Reply Last reply Reply Quote 0
                        • N
                          niiccooo1 @Nordischerjung last edited by

                          @nordischerjung

                          Damit klappt es nicht so wie gewünscht. Die Lösung @Codierknecht passt zu meinem Vorhaben besser.

                          Vielen Dank trotzdem!

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

                            @niiccooo1
                            Ein "wiederhole solange" kann kritisch werden. Wenn es keine saubere Abbbruchbedingung gibt, hat man sich schnell eine Endlosschleife produziert.
                            Ein Schleife über die Elemente kennt bereits die Anzahl der Durchläufe ... nämlich die Zahl der Elemente.
                            Die ist für sowas in aller Regel besser geeignet.

                            Wenn's läuft, bearbeite bitte Deinen Eingangspost und setze ein "[gelöst] " vor den Titel.

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

                            Support us

                            ioBroker
                            Community Adapters
                            Donate
                            FAQ Cloud / IOT
                            HowTo: Node.js-Update
                            HowTo: Backup/Restore
                            Downloads
                            BLOG

                            764
                            Online

                            31.6k
                            Users

                            79.5k
                            Topics

                            1.3m
                            Posts

                            6
                            17
                            1126
                            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