NEWS
[gelöst] Javascript Objekte Zugriff
-
Das Problem ist ja, dass ich den Namen nicht kenne, bzw ermittlen muss
das wird nicht gehen oder ?
-
Mal als Idee…
Über Javascript aufs Dateisystem zugreifen, die objects.json einlesen und auswerten?
-
Ich werde mich mal belesen, ich makiere den Fred dann als gelöst wenns funktioniert
-
Das Problem ist ja, dass ich den Namen nicht kenne, bzw ermittlen muss, das wird nicht gehen oder ? `
Den Namen ermitteln kann man nicht. Der Name wird allerdings beim Erstellen des Schedules von Dir vergeben.
@ruhr70:Über Javascript aufs Dateisystem zugreifen, die objects.js einlesen und auswerten? `
Die Datei objects.json einzulesen, ist wegen ihrer Größe wohl eher eine theoretische Möglichkeit. -
Das Problem ist ja, dass ich den Namen nicht kenne, bzw ermittlen muss, das wird nicht gehen oder ? `
Den Namen ermitteln kann man nicht. Der Name wird allerdings beim Erstellen des Schedules von Dir vergeben.
@ruhr70:Über Javascript aufs Dateisystem zugreifen, die objects.js einlesen und auswerten?
Die Datei __objects.json__ einzulesen, ist wegen ihrer Größe wohl eher eine theoretische Möglichkeit.
Ich habe das mal gerade ausprobiert. Funktioniert auch praktisch:
var datei = "/opt/iobroker/objects.json.test"; var fs = require('fs'); fs.readFile(datei, function(err, json) { if(err) log('Fehler Datei lesen: ' + err, 'error'); else { log("Abfrage durchgeführt"); var obj = JSON.parse(json); for(var index in obj) { // var indexObj = JSON.stringify(obj); if (/^fullcalendar/gi.test(index)) { log(index); log(JSON.stringify(obj[index])); } } } });
Ergebnis hier im Beispiel:
- Name aller vorhandenen Objekte im Fullcalendar und deren Inhalt
javascript.1 2018-04-18 18:27:40.873 info script.js.test: {"_id":"fullcalendar.0.2018-04-18T17_16_121","common":{"name":"Test","enabled":true},"native":{"id":1524064572152,"start":"2018-04-19T10:00:00","type":"single","durationEditable":false javascript.1 2018-04-18 18:27:40.873 info script.js.test: fullcalendar.0.2018-04-18T17_16_121 javascript.1 2018-04-18 18:27:40.873 info script.js.test: {"_id":"fullcalendar.0.info","type":"channel","common":{"name":"Information"},"native":{},"from":"system.host.iobrokerng2.cli","ts":1512216110134,"acl":{"object":1636,"owner":"system.u javascript.1 2018-04-18 18:27:40.873 info script.js.test: fullcalendar.0.info javascript.1 2018-04-18 18:27:40.873 info script.js.test: {"_id":"fullcalendar.0.info.lastConfiguredEvent","type":"state","common":{"role":"state","name":"Last configured event","type":"json","read":true,"write":false},"native":{},"from":"sys javascript.1 2018-04-18 18:27:40.873 info script.js.test: fullcalendar.0.info.lastConfiguredEvent javascript.1 2018-04-18 18:27:40.873 info script.js.test: {"_id":"fullcalendar.0.info.lastEvent","type":"state","common":{"role":"state","name":"Any last event","type":"json","read":true,"write":false},"native":{},"from":"system.host.iobroker javascript.1 2018-04-18 18:27:40.873 info script.js.test: fullcalendar.0.info.lastEvent javascript.1 2018-04-18 18:27:40.873 info script.js.test: {"type":"meta","common":{"name":"fullcalendar","type":"www"},"from":"system.host.iobrokerng2.cli","ts":1512216110017,"native":{},"_id":"fullcalendar","acl":{"object":1636,"owner":"syst javascript.1 2018-04-18 18:27:40.873 info script.js.test: fullcalendar javascript.1 2018-04-18 18:27:40.873 info script.js.test: {"type":"meta","common":{"name":"admin","type":"admin"},"from":"system.host.iobrokerng2.cli","ts":1512216109147,"native":{},"_id":"fullcalendar.admin","acl":{"object":1636,"owner":"sys javascript.1 2018-04-18 18:27:40.873 info script.js.test: fullcalendar.admin javascript.1 2018-04-18 18:27:40.873 info script.js.test: Abfrage durchgeführt javascript.1 2018-04-18 18:27:40.328 info script.js.test: registered 0 subscriptions and 0 schedules javascript.1 2018-04-18 18:27:40.327 info Start javascript script.js.test
Da ich noch ein Rechteproblem beim Einlesen der objects.json hatte (habe ich nicht weiter verfolgt), habe ich die Datei als objects.json.test eine Ebene höher kopiert.
Wenn das weiter verfolgt werden soll, muss man sich einmal das Rechtethema ansehen.
Das Grundgerüst zum einlesen der Datei ist von Paul53 geklaut.
-
Der Durchlauf und die Verarbeitung hat 500ms gedauert.
-
var obj = JSON.parse(json); for(var index in obj) { // var indexObj = JSON.stringify(obj); if (/^fullcalendar/gi.test(index)) { log(index); log(JSON.stringify(obj[index])); } } ```` `
Das Erzeugen des riesigen Objektes per JSON.parse(json) würde ich sparen (Speicherbedarf !) und die IDs folgendermassen ermitteln:
var pos = 0; do { pos = json.indexOf('fullcalendar.0.20', pos + 60); var id = json.substr(pos, 35); if(id.indexOf('pos') == -1 && id.length == 35) { log(id); // Hier kann mit getObject(id) die Auswertung erfolgen } } while(pos != -1);
Wenn man die ID hat, kommt man mit getObject(id) an alle Eigenschaften.
-
Dann kommt aber leider die Fehlermeldung
TypeError: json.substr is not a function
Edit:
Habs jetzt hinbekommen anscheinend ist 'json' ein Objekt und kein String. (Stimmt das ?)
Deshalb hab ichs jetzt mal so probiert (php Kentnisse sei Dank :D)
json.toString().substr
Und es geht
-
Bei mir funktioniert https://wiki.selfhtml.org/wiki/JavaScript/Objekte/String/substr.
-
anscheinend ist 'json' ein Objekt und kein String. (Stimmt das ?) `
Nein, json ist ein String. Die Datei objects.json enthält einen JSON-String.Hast Du die Datei eingelesen ?
const datei = "/opt/iobroker/iobroker-data/objects.json";
-
Ja wobei bei mir ein Rechteproblem auftritt
Welche Rechte muss ich den geben ?
Selbst mit chmod 777 gehts nicht
-
Ja wobei bei mir ein Rechteproblem auftritt `
Ich vermute das Problem eher dadurch, dass die Datei durch ioBroker geöffnet ist. -
Die Fehlermeldung lautet aber:
Error: Permission denied May not read /opt/iobroker/iobroker-data/objects.json
-
Die Fehlermeldung lautet aber: `
Vielleicht hat node.js fs ein Problem mit der Dateiendung .json ?Unter Windows habe ich mal die Datei kopiert und dann die Kopie eingelesen, was funktioniert
exec('copy C://Program Files//ioBroker//iobroker-data//objects.json G://opt//iobroker//iobroker-data//objects.test'); const datei = "G://opt//iobroker//iobroker-data//objects.test";
Und Du hast recht: Man muss .toString() anwenden
json = json.toString(); var pos = 0; do {
-
Wenn ich die Datei kopiere und umbenenne in z.B nur "obj.json" im gleichen Verzeichnis, dann funktioniert das ganze
Macht irgendwie keinen Sinn, wiee ich finde
Edit:
Diese Funktion gibt den Fehler aus:
mods.fs.readFile = function () { if (mods.path.normalize(arguments[0]).replace(/\\/g, '/').indexOf('-data/objects.json') !== -1) { if (adapter) { adapter.log.error('May not read ' + arguments[0]); } else { console.error('May not read ' + arguments[0]); } throw new Error('Permission denied'); } return mods.fs._readFile.apply(this, arguments); };
Die if-Abfrage prüft ob der angegebene Pfad '-data/objects.json' enthält, dass ist anscheinend nicht gewollt ?
Gruß Finn
Edit2: habs gelöst. Ich kopiere einfach die Datei in eine obj.json und lese dann diese aus.
Vielen Dank für eure Hilfe