NEWS
Werte aus XML auslesen
-
@claus1993
Blockly ist damit sicherlich überfordert. Für Javascript gibt es das NPM-Modul xml2js (in die Konfiguration der JS-Instanz eintragen). -
Danke, doch habe ich keinerlei Ahnung von Java und bereits mit Blockly meine Probleme....
Kann ich denn mit dem Modul einen Datensatz einfliesen lassen und bekomme dann meine Daten entsprechend konvertiert? Wie muss ich mir das vorstellen?
-
@claus1993 sagte:
Kann ich denn mit dem Modul einen Datensatz einfliesen lassen
Woher kommen die XML Daten ? Liegen sie in einem Datenpunkt vor ?
Das NPM-Modul wandelt XML in ein Javascript-Objekt. -
@paul53
Den Datensatz muss ich über einen HTML Befehl abfragen. Wollte dann eigentlich alles im Script mittels Variablen verarbeiten, kann es aber auch als Datenpunkt abspeichern was jedoch etwas Performance kostet.Habe diverse Datensätze mit gleichbleibender Struktur. Bin noch am tüfteln ob ich die einzelnen Werte nicht nacheinander mittels den Textbausteinen auslesen und in einer Liste abspeichern kann. Mit der Liste müsste ich dann auch weiterkommen....
-
Damit ich das NPM Modul besser verstehe hätte ich dazu ein paar Fragen. Habe hierzu mal einen Skript als Beispiel;
var link = 'http://192.168.2.104/config/xmlapi/rssilist.cgi'; var request = require('request'); var parseString = require('xml2js').parseString;</code> function ImportRSSI() { request(link, function (error, response, body) { var xml, result; parseString(body, function (err, result) { for (var i = 0; i < result.rssiList.rssi.length; i++) { var Device = result.rssiList.rssi[i].$; var DeviceId = Device.device; var DeviceTx = Device.tx; var DeviceRx = Device.rx; createState('HMSignalStrength.'+DeviceId+'.tx', DeviceTx, true); createState('HMSignalStrength.'+DeviceId+'.rx', DeviceRx, true); } }); }); } ImportRSSI();
- bei "var link" gebe ich meine URL ein
- um an die Daten aus der Rückmeldung zu gelangen lege ich weitere Variablen an;
- "var DeviceID" heißt die Variable die mit den Daten von dem Label "Device.device" gefüllt wird
- mittels create state lege ich meinen Datenpunkt an wo dann meine Variablen rein geschrieben werden
Passt meine Denkweise soweit und ich kann - den Script entsprechend angepasst - die XML Daten in ioBroker schreiben?
Habe ich ggf noch was vergessen was ich beachten muss?Danke dir und ein frohes Weihnachtsfest!!!
-
@claus1993 sagte:
Ob die Schleife so funktioniert, kann ich nicht beurteilen, da ich das aus dem XML erzeugte Objekt nicht kenne. Poste mal eine Log-Ausgabe davon.
const link = 'http://192.168.2.104/config/xmlapi/rssilist.cgi'; const parseString = require('xml2js').parseString; function ImportRSSI() { request(link, function (error, response, body) { parseString(body, function (err, result) { if(!err) log('Objekt: ' + result) }); }); } ImportRSSI();
Dein Script lässt sich aufgrund fehlender Einrückungen schlecht lesen.
-
@claus1993 sagte:
createState('HMSignalStrength.'+DeviceId+'.tx', DeviceTx, true);
Da createState() nur einen Datenpunkt erstellt, wenn er noch nicht vorhanden ist, solltest Du es ändern in
let idTx = 'HMSignalStrength.'+DeviceId+'.tx'; if(existsState(idTx)) setState(idTx, DeviceTx, true); else createState(idTx, DeviceTx, {type: 'number', unit: 'dBm', name: 'RSSI Tx ' + DeviceId, role: 'value'});
-
Das ist die Rückmeldung meiner CCU;
<rssiList> <rssi device="KEQ1070665" rx="-82" tx="-191"/> <rssi device="LEQ0428002" rx="65536" tx="-72"/> <rssi device="MEQ0050668" rx="-63" tx="-69"/> <rssi device="MEQ0228764" rx="-191" tx="-82"/> <rssi device="MEQ1562779" rx="-72" tx="65536"/> <rssi device="NEQ1469139" rx="65536" tx="-83"/> <rssi device="NEQ1692724" rx="-58" tx="-199"/> <rssi device="NEQ1692751" rx="-60" tx="-176"/> <rssi device="NEQ1802107" rx="-128" tx="-73"/> <rssi device="NEQ1838061" rx="65536" tx="-65"/> <rssi device="OEQ0087000" rx="65536" tx="-82"/> <rssi device="OEQ0801793" rx="65536" tx="-69"/> <rssi device="OEQ1994774" rx="-70" tx="-78"/> </rssiList>
Auswerten möchte ich jedoch die Daten aus diesem XML;
jetzt muss ich natürlich die Variablen anpassen und erweitern. Was muss ich abfragen um den Namen zu erhalten? fsapiResponse.item key.field name ?
-
@claus1993 sagte:
Auswerten möchte ich jedoch die Daten aus diesem XML;
XML kann ich nicht interpretieren. Wie sieht das Objekt als Ergebnis von xml2js aus ?
parseString(xml, function (err, result) { if(!err) log('Objekt: ' + result) });
-
@claus1993 sagte:
fsapiResponse.item key.field name ?
result.fsapiResponse.item ist ein Array (2 Elemente)
result.fsapiResponse.item[0].field ist ein Array (6 Elemente)
result.fsapiResponse.item[0].field[0].c8_array[0] liefert "Shared media"
result.fsapiResponse.item[0].field[0].$.name liefert "name"