NEWS
daten über REST Schnittstelle lesen
-
@ben1983 sagte: wie komme ich jetzt an den wert? in dfem fall 250
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=45;PowerActive;SUM13'; request(url, function(error, response, result) { if(error) log(error, 'warn'); else { let value = JSON.parse(result).value; log('Wirkleistung: ' + value['45.PowerActive.SUM13']); } }); -
@paul53 Kannst DU mir noch sagen, wie Du in der Doku darauf gekommen bist?
Falls ich später noch sowas wie historische Daten auslesen will, kann ich es darauf adaptieren.
Also ich habe die Zusammensetzung der werte nicht gefunden in der Doku.
-
@paul53 Würde mir gerne hierzu ne Struktur erstellen,
Welche Folgendes enthält:
DeviceId
Parameter 1,Parameter2....
IDParameter1,IdParameter2...Geht das vielleicht irgendwie so:
Let Device = { „ID“: 45, „Parameter“:[„abc“,“def“],“IdPara“:[„a“,“b“]};???
-
@paul53 Würde mir gerne hierzu ne Struktur erstellen,
Welche Folgendes enthält:
DeviceId
Parameter 1,Parameter2....
IDParameter1,IdParameter2...Geht das vielleicht irgendwie so:
Let Device = { „ID“: 45, „Parameter“:[„abc“,“def“],“IdPara“:[„a“,“b“]};???
-
@ben1983 sagte: Würde mir gerne hierzu ne Struktur erstellen
Was willst Du damit machen? Woher sollen die Parameter kommen?
-
@ben1983 sagte: Würde mir gerne hierzu ne Struktur erstellen
Was willst Du damit machen? Woher sollen die Parameter kommen?
@paul53 Habe es jetzt so realisiert, funktioniert top.
let Device = []; let i = 0; // Talstraße 1A Messgruppe 1 Device[i] = {'ID':'27','Value':[{"Name":"PowerActive","Type":"SUM13","InternalId":IdWirkleistungGesamt}]}; i = i + 1; // Talstraße 1A Messgruppe 2 Device[i] = {'ID':'28','Value':[{"Name":"PowerActive","Type":"Input05","InternalId":IdWirkleistungGarageII}, {"Name":"PowerActive","Type":"Input06","InternalId":IdWirkleistungPv}, {"Name":"PowerActive","Type":"Input07","InternalId":IdWirkleistungGarageI}, {"Name":"PowerActive","Type":"Input08","InternalId":IdWirkleistungAussensteckdosen}]}; i = i + 1; Device.forEach(function (MyDevice) { let DeviceID = MyDevice.ID; MyDevice.Value.forEach(function (MyValue) { const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues?value=' + DeviceID + ';' + MyValue.Name + ';' + MyValue.Type; request(url, function(error, response, result) { if(error) { log(error, 'warn'); } else { let value = JSON.parse(result).value; value = Math.round(value[DeviceID + '.' + MyValue.Name + '.' + MyValue.Type]); setState(MyValue.InternalId,value); } }); }); }); -
@ben1983 sagte: Würde mir gerne hierzu ne Struktur erstellen
Was willst Du damit machen? Woher sollen die Parameter kommen?
-
@paul53 die historischen Daten bekomme ich als XML zurück.
Gibts da auch ne gute Pars Methode? -
-
@paul53 Oh man, warum gibt man jetzt die einen daten so aus, die anderen so... naja hat vielleicht nen guten Hintergrund, aber dann belasse ich es erst mal bei den online werten.
-
@ben1983 sagte: warum gibt man jetzt die einen daten so aus, die anderen so...
Kann man nicht mittels /.json die Ausgabe als JSON veranlassen?
Bei der Eingabe:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/45/hist/energy/ActiveEnergyConsumed/SUM13?start=NAMED_LastMonth&end=NAMED_LastMonth/.json'Erscheint:
3548) script.js.common.GridVis: <?xml version="1.0" encoding="UTF-8" standalone="yes"?><energy><endTime>1622498399999000000</endTime><energy>278104.0</energy><startTime>1619820000000000000</startTimBei:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/45/hist/energy/ActiveEnergyConsumed/SUM13?start=NAMED_LastMonth&end=NAMED_LastMonth/.json'Erscheint:
3548) script.js.common.GridVis: RestDateException:Convert failed for format NAMED:No enum constant de.janitza.pasw.device.core.api.tools.StartEndPoints.LastMonth/.json -
Bei der Eingabe:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/45/hist/energy/ActiveEnergyConsumed/SUM13?start=NAMED_LastMonth&end=NAMED_LastMonth/.json'Erscheint:
3548) script.js.common.GridVis: <?xml version="1.0" encoding="UTF-8" standalone="yes"?><energy><endTime>1622498399999000000</endTime><energy>278104.0</energy><startTime>1619820000000000000</startTimBei:
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/45/hist/energy/ActiveEnergyConsumed/SUM13?start=NAMED_LastMonth&end=NAMED_LastMonth/.json'Erscheint:
3548) script.js.common.GridVis: RestDateException:Convert failed for format NAMED:No enum constant de.janitza.pasw.device.core.api.tools.StartEndPoints.LastMonth/.json -
@ben1983 Versuche mal
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/45/hist/energy/ActiveEnergyConsumed/SUM13/.json?start=NAMED_LastMonth&end=NAMED_LastMonth';@paul53 danke.
Genial, scheint zu funktionierenHabe jetzt meine Anfrage der onlinewerte auch so gemacht, um es einheitlich zu haben.
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/onlinevalues/.json?value=' + DeviceID + ';' + MyValue.Name + ';' + MyValue.Type; -
@ben1983 Versuche mal
const url = 'http://localhost:8080/rest/1/projects/EnergieMonitoring/devices/45/hist/energy/ActiveEnergyConsumed/SUM13/.json?start=NAMED_LastMonth&end=NAMED_LastMonth';@paul53 stehe grad auf den sxhlauch, wie ich an den enegy wert kommen soll.
klappt irgendwie nicht.das bekomme ich als result zurück:
692) script.js.common.GridVis: {"startTime":1619820000000000000,"endTime":1622498399999000000,"unit":"Wh","energy":278104.0,"valueType": -
@paul53 stehe grad auf den sxhlauch, wie ich an den enegy wert kommen soll.
klappt irgendwie nicht.das bekomme ich als result zurück:
692) script.js.common.GridVis: {"startTime":1619820000000000000,"endTime":1622498399999000000,"unit":"Wh","energy":278104.0,"valueType": -
@paul53 Ich wollte gerade einmal etwas herum probieren, um weiter ins Thema zu kommen:
warum geht das hier nicht mit dem parse?
klar ich könnte direkt auf c zugreifen, aber ist das so also kein JSON?let a = {"b":"abc","c":"efg"}; let c = JSON.parse(a).c; log(c);wollte herausfinden, warum bei den onlinewerten das ergebnis des Parse ein "array" mit string index ist.
klar, weil der value als wert wieder geschweifte klammern enthält.
bin da noch nicht so drin im JSON. -
@paul53 Ich wollte gerade einmal etwas herum probieren, um weiter ins Thema zu kommen:
warum geht das hier nicht mit dem parse?
klar ich könnte direkt auf c zugreifen, aber ist das so also kein JSON?let a = {"b":"abc","c":"efg"}; let c = JSON.parse(a).c; log(c);wollte herausfinden, warum bei den onlinewerten das ergebnis des Parse ein "array" mit string index ist.
klar, weil der value als wert wieder geschweifte klammern enthält.
bin da noch nicht so drin im JSON. -
@ben1983 sagte: aber ist das so also kein JSON?
Nein, JSON ist ein String:
let a = '{"b":"abc","c":"efg"}';Das andere ist ein Objekt:
let a = {"b":"abc","c":"efg"}; log(a.c);@paul53 Ah OK, aber warum geht dann bspw. hier Version 1 und 2, aber 3 nicht mehr?
//1 let a = '{"b":"abc","c":"efg"}'; let c = JSON.parse(a).c; log(c); //2 let b = '{"value":{"b":"abc","c":"efg"}}'; let d = JSON.parse(b).value; log(d["c"]); //3 let e = JSON.parse(d).c; log(e);
Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.
Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.
Mit deinem Input könnte dieser Beitrag noch besser werden 💗
Registrieren Anmelden
