Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Deutsch
    3. ioBroker Allgemein
    4. JSON interpretieren

    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

    JSON interpretieren

    This topic has been deleted. Only users with topic management privileges can see it.
    • 1
      150d last edited by 150d

      Hallo zusammen,

      ich schreibe gerade an einem Adapter, der eine Web-API abfragt und ein JSON zurückbekommt. Dieses zu interpretieren gelingt mir jetzt nicht:

      adapter.log.info("parse JSON: " + JSON.stringify(json));

      ergibt:

      parse JSON: {"overview":{"lastUpdateTime":"2023-07-21 17:03:35","lifeTimeData":{"energy":860933},"lastYearData":{"energy":319056},"lastMonthData":{"energy":319056},"lastDayData":{"energy":24741},"currentPower":{"power":2135},"measuredBy":"INVERTER"}}

      -> fein.

      Aber wie greife ich darauf jetzt zu?

      data = JSON.parse(json);

      ergibt:

      Unexpected token o in JSON at position 1

      -> Verstehe ich nicht. In dem JSON gibt es doch gar kein Token namens "o"?

      Kann mir jemand sagen, was ich hier falsch mache?

      MfG

      PS: Ja, ich hätte auch gedacht, daß dieser Post in "Entwicklung" besser aufgehoben wäre. Aber dort habe ich kein Schreibrecht, und dies zu bekommen scheint nicht ganz trivial zu sein. Falls sich jemand berufen fühlt, mir hier beizustehen, so sei mir dieser willkommen! 🙂

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

        @150d Was soll das Ganze mit dem parse JSON

        das ist doch kein valider JSON:

        parse JSON: {"overview":{"lastUpdateTime":"2023-07-21 17:03:35","lifeTimeData":{"energy":860933},"lastYearData":{"energy":319056},"lastMonthData":{"energy":319056},"lastDayData":{"energy":24741},"currentPower":{"power":2135},"measuredBy":"INVERTER"}}
        

        ohne das Zeugs vornedran ist es doch in Ordnung:

        {"overview":{"lastUpdateTime":"2023-07-21 17:03:35","lifeTimeData":{"energy":860933},"lastYearData":{"energy":319056},"lastMonthData":{"energy":319056},"lastDayData":{"energy":24741},"currentPower":{"power":2135},"measuredBy":"INVERTER"}}
        

        Daraus kann man dann ein Objekt machen und auf die Eigenschaften zugreifen - aber das parse JSON vorne dran machst Du alles kaputt. Wenn das vorher bereits ein JSON war - dann braucht man das auch nicht "stringifizieren".

        1 1 Reply Last reply Reply Quote 0
        • 1
          150d @mickym last edited by

          @mickym Das ist doch nur der Prefix für die Log-Ausgabe. Die Variable "json" beginnt mit "{".

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

            @150d Wo ist das Problem?

            let str = '{"overview":{"lastUpdateTime":"2023-07-21 17:03:35","lifeTimeData":{"energy":860933},"lastYearData":{"energy":319056},"lastMonthData":{"energy":319056},"lastDayData":{"energy":24741},"currentPower":{"power":2135},"measuredBy":"INVERTER"}}';
            
             
            var wert= JSON.parse(str).overview.lastUpdateTime;
            console.log(wert);
            

            Ich kann also auf jede Eigenschaft zugreifen.

            3f6a53ba-6a2c-4024-932a-ce8a9e880d33-image.png

            Das Ganze Objekt ist nur das Parsen des Strings.

            45687306-829a-42cf-b600-dcd21ff1f707-image.png

            Aus Deinem Code geht nicht hervor was in json drin steht -

            1 1 Reply Last reply Reply Quote 0
            • 1
              150d @mickym last edited by

              @mickym Ich verstehe nicht, warum

              data = JSON.parse(json);

              nicht funktioniert. Das sollte mir doch ein JavScript-Objekt mit den JSON-Inhalten zurückgeben, nicht?

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

                @150d Ja tuts ja - Nenn mal Deine Variable nicht json sondern str oder irgendwas. - Du siehst doch dass ich mit Deinem JSON string kein Problem habe. Der String muss in "Hochkommas"

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

                  @150d sagte: warum
                  data = JSON.parse(json);
                  nicht funktioniert.

                  Ist das vermeintliche JSON vielleicht kein JSON, sondern bereits ein Objekt?

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

                    @paul53 sagte in JSON interpretieren:

                    @150d sagte: warum
                    data = JSON.parse(json);
                    nicht funktioniert.

                    Ist das vermeintliche JSON vielleicht kein JSON, sondern bereits ein Objekt?

                    Ja das kann SEIN, weil sonst würde er es oben ja nicht stringifizieren.

                    1 1 Reply Last reply Reply Quote 0
                    • 1
                      150d @mickym last edited by 150d

                      In der Tat, das funktioniert. (Ich bin neu hier - bei JavaScript -; ich weiß noch nicht so genau, was ich tue... 🙂 )

                      Was ich möchte:

                      Der JSON-String soll rekursiv geparst werden und aus dem Inhalt ioBroker-States angelegt werden. Folgendes habe ich versucht:

                      function parse_json_data(jsondata) {
                      
                      	for (var substr in jsondata) {
                      		
                      		if (typeof substr === "object") {
                      			return parse_json_data(substr);
                      		} else {
                      			adapter.log.info("substring: " + substr);
                      		}
                      		
                      	}
                      
                      }
                      
                      

                      Das klappt aber nicht, es wird nur der eine Eintrag "overview" erkannt. Die Rekursion funktioniert nicht.

                      Wie kann ich zwischen "Knoten" und "Blatt" unterscheiden?

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

                        gelöscht - du hast ja for in genutzt, aber substr ist der Key und nicht das Objekt.

                        1 1 Reply Last reply Reply Quote 0
                        • 1
                          150d @mickym last edited by 150d

                          (delete - checking... 🙂 )

                          mickym OliverIO 2 Replies Last reply Reply Quote 0
                          • mickym
                            mickym Most Active @150d last edited by mickym

                            @150d

                            if (typeof jsondata[substr] === "object"){
                            			return parse_json_data(jsondata[substr] );
                            		}
                            

                            In substr ist der key - als der Eigenschaftsname des Wertes innerhalb des Objektes. Wenn die Eigenschaft wieder auf Objekt abprüfst, musst Du das über das Objekt referenzieren.

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

                              @150d sagte: Der JSON-String soll rekursiv geparst werden und aus dem Inhalt ioBroker-States angelegt werden.

                              Das macht man nicht mit dem JSON, sondern mit dem Objekt. Beispiel:

                              const path = '0_userdata.0.inverter';
                              const myobj = {"overview":{"lastUpdateTime":"2023-07-21 17:03:35","lifeTimeData":{"energy":860933},"lastYearData":{"energy":319056},"lastMonthData":{"energy":319056},"lastDayData":{"energy":24741},"currentPower":{"power":2135},"measuredBy":"INVERTER"}};
                              
                              function iter(id, obj) {
                                for(let prop in obj) {
                                    if(typeof obj[prop] == 'object') iter(id + '.' + prop, obj[prop]);
                                    else {
                                      let idDp = id + '.' + prop;
                                      log(idDp + ': ' + obj[prop]);
                                      // if(existsState(idDp)) setState(idDp, obj[prop]);
                                      // else createState(idDp, obj[prop]);
                                    }  
                                }
                              }
                               
                              iter(path, myobj);
                              
                              1 Reply Last reply Reply Quote 0
                              • OliverIO
                                OliverIO @150d last edited by OliverIO

                                @150d

                                du kannst das mal probieren

                                function iterate(obj, stack) {
                                        for (var property in obj) {
                                            if (obj.hasOwnProperty(property)) {
                                                if (typeof obj[property] == "object") {
                                                    iterate(obj[property], stack + '.' + property);
                                                } else {
                                                    console.log(property + "   " + obj[property]);
                                                }
                                            }
                                        }
                                    }
                                
                                iterate(object, '')
                                
                                

                                https://stackoverflow.com/questions/15690706/recursively-looping-through-an-object-to-build-a-property-list

                                ich sehe ich gerade, das die stackvariable irgendwie nirgends zugewiesen wird, eigentlich sollte die dafür da sein, um den propertypfad mit auszugeben.

                                Nachtrag, das war Paul schneller
                                Evtl musst du auch noch Sonderbehandlung für Array und den anderen primitivtypen einbauen

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

                                  Ok, bin weitergekommen. Die Rekursion funktioniert jetzt "nach unten", aber sie "kommt nicht wieder hoch":

                                  Nochmal zur Erinnerung das JSON, "prettified":

                                  {
                                  	"overview":{
                                  		"lastUpdateTime":"2023-07-21 18:41:46",
                                  		"lifeTimeData":{
                                  			"energy":863588
                                  		},
                                  		"lastYearData":{
                                  			"energy":321711
                                  		},
                                  		"lastMonthData":{
                                  			"energy":321711
                                  		},
                                  		"lastDayData":{
                                  			"energy":27396
                                  		},
                                  		"currentPower":{
                                  			"power":1152
                                  		},
                                  		"measuredBy":"INVERTER"
                                  	}
                                  }
                                  

                                  Und hier der Code, den ich bis jetzt habe:

                                  function parse_json_data(jsondata, prefix) {
                                  	
                                  	for (var substr in jsondata) {
                                  		
                                  		if (typeof jsondata[substr] === "object") {
                                  			
                                  			// found object, do recursion:
                                  			
                                  			return parse_json_data(jsondata[substr], prefix + substr + ".");
                                  
                                  		} else {
                                  			
                                  			// not an object, print key/value pair:
                                  			
                                  			adapter.log.info("JSON key/value: " + prefix + substr + " = " + jsondata[substr]);
                                  				
                                  		}
                                  	}
                                  }
                                  
                                  

                                  Dies produziert folgende Ausgabe:

                                  	JSON key/value: overview.lastUpdateTime = 2023-07-21 18:41:46
                                  	JSON key/value: overview.lifeTimeData.energy = 863588
                                  
                                  

                                  ... es wird also:

                                  • das erste Objekt identifiziert (overview),
                                  • darin ein key/value gefunden (lastUpdateTime),
                                  • dann wieder ein Objekt (lifeTimeData),
                                  • darin ein key/value (energy).

                                  Aber dann ist Schluss, weitere Behandlung findet nicht mehr statt.

                                  Warum geht die for-Schleife nicht zum nächsten item (lastYearData) weiter?

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

                                    @150d
                                    Bei meinem Vorschlag kommt das im Log:

                                    19:08:57.895	info	javascript.1 (2174) script.js.common.ObjectStruct2ID: 0_userdata.0.inverter.overview.lastUpdateTime: 2023-07-21 17:03:35
                                    19:08:57.895	info	javascript.1 (2174) script.js.common.ObjectStruct2ID: 0_userdata.0.inverter.overview.lifeTimeData.energy: 860933
                                    19:08:57.895	info	javascript.1 (2174) script.js.common.ObjectStruct2ID: 0_userdata.0.inverter.overview.lastYearData.energy: 319056
                                    19:08:57.895	info	javascript.1 (2174) script.js.common.ObjectStruct2ID: 0_userdata.0.inverter.overview.lastMonthData.energy: 319056
                                    19:08:57.895	info	javascript.1 (2174) script.js.common.ObjectStruct2ID: 0_userdata.0.inverter.overview.lastDayData.energy: 24741
                                    19:08:57.895	info	javascript.1 (2174) script.js.common.ObjectStruct2ID: 0_userdata.0.inverter.overview.currentPower.power: 2135
                                    19:08:57.896	info	javascript.1 (2174) script.js.common.ObjectStruct2ID: 0_userdata.0.inverter.overview.measuredBy: INVERTER
                                    

                                    Das return in Zeile 9 verhindert die weitere Iteration.

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

                                      @paul53 said in JSON interpretieren:

                                      Das return in Zeile 9 verhindert die weitere Iteration.

                                      Jawohl, das war es. (Dieses JavaScript ist vielleicht krümelkackerisch... 🙂 )

                                      Danke!

                                      Und danke an alle beteiligten!

                                      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

                                      916
                                      Online

                                      31.9k
                                      Users

                                      80.1k
                                      Topics

                                      1.3m
                                      Posts

                                      4
                                      17
                                      539
                                      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