NEWS
Täglicher Durchschnitt aus InfluxDB
-
Hi, also ich hab von JS eigentlich kaum Ahnung. Ziel ist den Durschnitt für den aktuellen Tag zu errechnen. Die Historie des DPs liegt in der InfluxDB. Von diesem DP wird der aktuelle Durschnitt benötigt.
Mithilfe einer Vorlage, ChatGPT und paar Ergänzungen meiner Wenigkeit sieht mein Skript wie folgt aus:var now = new Date(); var startOfDay = new Date(now.getFullYear(), now.getMonth(), now.getDate() - 1, 0, 0, 0).getTime(); var endOfDay = new Date(now.getFullYear(), now.getMonth(), now.getDate() - 1, 23, 59, 59).getTime(); var end = Date.now(); sendTo('influxdb.0', 'getHistory', { id: '0_userdata.0.AutarkieinProzent', options: { start: startOfDay, end: endOfDay, aggregate: 'onchange', addId: true } }, function (result) { for (var i = 0; i < result.result.length; i++) { console.log(i + ' ' + new Date(result.result[i].ts).toISOString()); } }); // console.log(result.result[i].id + ' ' + new Date(result.result[i].ts).toISOString());Die Daten habe ich, aber wie komme ich jetzt an den Durschnittswert? Es gibt ja auch eine average option...aber wie krieg ich das da korrekt rein?
Und das Ergebnis soll in ein DP geschrieben werden. Aber wie? -
Hi, also ich hab von JS eigentlich kaum Ahnung. Ziel ist den Durschnitt für den aktuellen Tag zu errechnen. Die Historie des DPs liegt in der InfluxDB. Von diesem DP wird der aktuelle Durschnitt benötigt.
Mithilfe einer Vorlage, ChatGPT und paar Ergänzungen meiner Wenigkeit sieht mein Skript wie folgt aus:var now = new Date(); var startOfDay = new Date(now.getFullYear(), now.getMonth(), now.getDate() - 1, 0, 0, 0).getTime(); var endOfDay = new Date(now.getFullYear(), now.getMonth(), now.getDate() - 1, 23, 59, 59).getTime(); var end = Date.now(); sendTo('influxdb.0', 'getHistory', { id: '0_userdata.0.AutarkieinProzent', options: { start: startOfDay, end: endOfDay, aggregate: 'onchange', addId: true } }, function (result) { for (var i = 0; i < result.result.length; i++) { console.log(i + ' ' + new Date(result.result[i].ts).toISOString()); } }); // console.log(result.result[i].id + ' ' + new Date(result.result[i].ts).toISOString());Die Daten habe ich, aber wie komme ich jetzt an den Durschnittswert? Es gibt ja auch eine average option...aber wie krieg ich das da korrekt rein?
Und das Ergebnis soll in ein DP geschrieben werden. Aber wie?fritzdect... durch deine ID ersetzen
sendTo('influxdb.0', 'query', 'SELECT mean("value") as "value" FROM "fritzdect.0.DECT_111111111.power" GROUP BY time(1d)', function (result) { if (result.error) { console.error(result.error); } else { // show result for (let a = 0; a < result.result[0].length;a++) { console.log('Mean values: ' + result.result[0][a].value); } } });
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