Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. Skripten / Logik
    4. Blockly
    5. [gelöst] JSON korrekt auslesen (AHOY Api)

    NEWS

    • Wir empfehlen: Node.js 22.x

    • Neuer Blog: Fotos und Eindrücke aus Solingen

    • ioBroker goes Matter ... Matter Adapter in Stable

    [gelöst] JSON korrekt auslesen (AHOY Api)

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

      @haselchen Wie gesagt lass Dir das mal im Debug Fenster ausgeben, nur so wirst Du letztlich Klarheit bekommen, was zu tun ist.

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

        @haselchen sagte in JSON korrekt auslesen (AHOY Api):

        Dementsprechend ist der Wert aus der API IMMER vorhanden und aktualisiert.

        ...wenn der Abruf fehlerfrei funktioniert hat!

        @haselchen sagte in JSON korrekt auslesen (AHOY Api):

        Mal klappt der Abruf im 2.Versuch,

        und der andere ist defrkt.

        also vor dem Auslesen erst prüfen, ob das Objekt auch drin steht

        haselchen 1 Reply Last reply Reply Quote 0
        • OliverIO
          OliverIO @haselchen last edited by

          @haselchen sagte in JSON korrekt auslesen (AHOY Api):

          Dementsprechend ist der Wert aus der API IMMER vorhanden und aktualisiert

          Nicht ganz.
          auch deine Gui schaut vorher ob das Objekt null ist, bevor es etwas macht.
          https://github.com/lumapu/ahoy/blob/868c49fdf4ff9e0c657120f2f92c49ffff57db38/src/web/html/index.html#L197

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

            @homoran

            Wie bekomme ich das ganze JSON in einen Datenpunkt?

            Dann könnte ich es ja aus diesem selektieren.

            @mickym

            Entweder habe ich nen ganzen Holzzaun vorm Kopp oder da kommt wirklich nichts als Info.

            Immer der cannot get Fehler.....

            OliverIO mickym Homoran 3 Replies Last reply Reply Quote 0
            • OliverIO
              OliverIO @haselchen last edited by

              @haselchen

              du kannst auch über die gui im browser mal mit den developer tools schauen,
              was da so ankommt. ob es wirklich immer gefüllt ist.

              Seite aufrufen.
              Dann F12
              Dann Tab Network
              Dann F5
              Dann nach den Einträgen zu api/index schauen

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

                @haselchen

                2325728b-c5f5-4f4b-9a69-55d2bd5a1e88-image.png

                Also wenn da kein Objekt zurückkommt, dann kannst auch kein Attribut auslesen. Dann musst halt erst mal mit Browser etc. versuchen zu schauen, was da zurückkommt.

                Kann es ggf. sein, dass noch eine Anmeldung erforderlich ist?

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

                  @haselchen sagte in JSON korrekt auslesen (AHOY Api):

                  Wie bekomme ich das ganze JSON in einen Datenpunkt?

                  debug result
                  bringt es zum Anzeigen

                  aktualisiere DP1 mit result
                  bringt es in einen Datenpunkt.
                  den kannst du sogar loggen

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

                    @mickym

                    script.js.Photovoltaikanlage.HM-600_Statistik: null
                    

                    Das ist das Ergebnis.
                    Was ist nicht kapiere.
                    Exakt die gleichen Blocklys und Einstellungen funktionieren beim anderen Wechselrichter.

                    Edit: nach dem 3.Abruf kommt das

                    	script.js.Photovoltaikanlage.HM-600_Statistik: {"generic":{"wifi_rssi":-69,"ts_uptime":5777,"menu_prot":false,"menu_mask":61,"menu_protEn":false,"esp_type":"ESP8266"},"ts_now":1689944699,"ts_sunrise":1689909623,"ts_sunset":1689967802,"ts_offset":0,"disNightComm":true,"inverter":[{"enabled":true,"id":0,"name":"HM-600","version":"10010","is_avail":true,"is_producing":true,"ts_last_success":1689944693}],"warnings":[],"infos":["MQTT is connected, 5728 packets sent, 0 packets received"]}
                    
                    mickym paul53 2 Replies Last reply Reply Quote 0
                    • mickym
                      mickym Most Active @haselchen last edited by mickym

                      @haselchen sagte in JSON korrekt auslesen (AHOY Api):

                      @mickym

                      script.js.Photovoltaikanlage.HM-600_Statistik: null
                      

                      Das ist das Ergebnis.
                      Was ist nicht kapiere.
                      Exakt die gleichen Blocklys und Einstellungen funktionieren beim anderen Wechselrichter.

                      Edit: nach dem 3.Abruf kommt das

                      	script.js.Photovoltaikanlage.HM-600_Statistik: {"generic":{"wifi_rssi":-69,"ts_uptime":5777,"menu_prot":false,"menu_mask":61,"menu_protEn":false,"esp_type":"ESP8266"},"ts_now":1689944699,"ts_sunrise":1689909623,"ts_sunset":1689967802,"ts_offset":0,"disNightComm":true,"inverter":[{"enabled":true,"id":0,"name":"HM-600","version":"10010","is_avail":true,"is_producing":true,"ts_last_success":1689944693}],"warnings":[],"infos":["MQTT is connected, 5728 packets sent, 0 packets received"]}
                      

                      Na das ist doch das was ich gemeint habe. Vielleicht ist das Ding einfach nicht so schnell und gibt nicht immer was zurück mach einfach noch eine Abfrage rein, dass es nicht null sein darf.

                      0a6ddf21-a1c3-44c1-9401-9e618d4150d2-image.png

                      Wenn das dann hinhaut, dann bist auf der sicheren Seite, dass dann nur dann was in den DP geschrieben wird, wenn der URL Aufruf ein Ergebnis liefert. Wäre im Prinzip halt generell eine grundsätzliche Möglichkeit um abzufangen, wenn mal nichts zurück kommt.

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

                        @mickym

                        Mega.
                        Da versuche ich was draus zu basteln.
                        Halber Tag schon wieder weg grmpf

                        Danke @Homoran + @OliverIO
                        für den Denkanstoss.

                        Gebe Feedback....

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

                          @haselchen Wenn was zurückkommt, dann passt Dein Aufruf jedenfalls:
                          57643dde-d2a8-4d13-97be-996ae1e4c714-image.png

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

                            ich glaube immer noch, dass man auf die Konvertierung verzichten können sollte.

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

                              @homoran Ja - kann schon sein. Wichtig ist aber doch in erster Linie abzufangen, wenn nichts zurück kommt.

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

                                @haselchen sagte: Das ist das Ergebnis.

                                Was wird in diesen Fällen in der Variablen error geliefert?

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

                                  @homoran sagte: ich glaube immer noch, dass man auf die Konvertierung verzichten können sollte.

                                  Ja, getAttr() nimmt die Konvertierung selbst vor, wenn erforderlich.

                                  1 Reply Last reply Reply Quote 0
                                  • haselchen
                                    haselchen Most Active @paul53 last edited by

                                    @paul53

                                    javascript.0	2023-07-21 15:20:00.088	error	script.js.Photovoltaikanlage.HM-600_Statistik: Cannot get inverter of null
                                    

                                    Das kommt, wenn ich nach 1min "Last Success" aus der API lesen und schreiben möchte.
                                    War die Frage , ob ich das richtig überhaupt ins Blockly gepackt hatte.

                                    293fa6db-77c5-459e-8c3f-c1dc8ceb0e27-grafik.png

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

                                      @haselchen sagte: Das kommt, wenn ich nach 1min "Last Success" aus der API lesen und schreiben möchte.

                                      Logge mal die Variable error, die neben result ebenfalls von request() geliefert wird.

                                      haselchen 1 Reply Last reply Reply Quote 0
                                      • haselchen
                                        haselchen Most Active @paul53 last edited by

                                        @paul53
                                        @Homoran
                                        @mickym
                                        @OliverIO

                                        Leute, dass ist wie immer grosses Kino mit euch!!!
                                        Alle Ideen zusammen haben den Erfolg gebracht.
                                        f3a58252-92dc-4b57-87b2-95a9821ec6f0-grafik.png

                                        Mit dem Blockly wird die null übersprungen und nur reale Werte in den DP geschrieben.
                                        Dauert manchmal 3-4min. aber ich bin schon froh, keine rote Farbe mehr im Log zu haben 😝

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

                                          @haselchen
                                          Funktioniert es nicht auch so?

                                          Blockly_temp.JPG

                                          haselchen 1 Reply Last reply Reply Quote 2
                                          • haselchen
                                            haselchen Most Active @paul53 last edited by

                                            @paul53

                                            Gerade getestet, natürlich funktioniert es so auch 🙂
                                            Nichts anderes habe ich erwartet 😂
                                            Skripttechnisch biste sowieso nicht von dieser Welt....

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

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            824
                                            Online

                                            32.0k
                                            Users

                                            80.4k
                                            Topics

                                            1.3m
                                            Posts

                                            5
                                            25
                                            528
                                            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